当前位置: 首页 > news >正文

沈阳小程序开发公司哪家好专业搜索引擎seo服务商

沈阳小程序开发公司哪家好,专业搜索引擎seo服务商,公司网页制作好了 怎么发布,摄影学校网站模板笔者在近一两年接触了Clickhouse数据库,在项目中也进行了一些实践,但一直都没有一些技术文章的沉淀,近期打算做个系列,通过一些具体的场景将Clickhouse的用法进行沉淀和分享,供大家参考。 首先我们假设一个Clickhouse数…

       笔者在近一两年接触了Clickhouse数据库,在项目中也进行了一些实践,但一直都没有一些技术文章的沉淀,近期打算做个系列,通过一些具体的场景将Clickhouse的用法进行沉淀和分享,供大家参考。

      首先我们假设一个Clickhouse数据表:

CREATE TABLE Test_Table (page_id String,  /* 页面ID */user_id String,  /* 用户ID */is_slow String,  /* 请求是否慢 */url String,      /* 请求URL */
) ENGINE = MergeTree()
ORDER BY (page_id, device_id);

这个表格的字段含义如注释,该表主要存储的数据是:

每个用户(user_id)在某个页面(page_id)发起的请求(url)是否耗时较长(is_slow),耗时较长我们简称“慢请求”

其中,一个用户可能在一个或多个页面发起一个或多个请求,每个请求可能是慢请求,也可能不是

is_slow的内容是枚举值,即:true 和 false

      数据表格有了,我们还要设定一个业务需求

我们期望以页面的纬度,查看每个页面中有多少用户遇到了慢请求,并算出在这个页面慢请求用户在所有页面发起请求的总用户数(无论是否发起了慢请求)的百分比

       从业务角度上比较好理解,这个结果其实就是想知道这个页面的慢影响了多少人,占比是多少

       从研发者的角度,一个页面一般是一个固定的团队成员开发,甚至就是一个团队成员开发,所以,这个角度主要面向问题的解决和责任的划分,同时也让项目的管理者,技术的管理者知道目前用户体验的痛点在哪里

       场景有了,业务需求也有了,那么如何实现呢?

       首先,我们要获取的内容有两个,一个是“每个页面中有多少用户遇到了慢请求

       这个比较简单:

    SELECT page_id, count(DISTINCT device_id) AS slow_user_countFROM Test_TableWHEREand is_slow = 'true'group by page_id

    另一个要获取的是“在所有页面发起请求的总用户数

 SELECT count(DISTINCT device_id) AS total_user_countFROM Test_Table

    最后,我们需要获得“在这个页面慢请求用户占在所有页面发起请求的总用户数(无论是否发起了慢请求)的百分比

     这里一般来说,比较常见的方法是使用With来进行拼接:

WITH slow_users AS (SELECT page_id, count(DISTINCT device_id) AS slow_user_countFROM Test_TableWHERE is_slow = 'true'group by page_id
),
total_users AS (SELECT count(DISTINCT device_id) AS total_user_countFROM Test_Table
)
SELECTslow_users.page_id,slow_users.slow_user_count,total_users.total_user_count,slow_user_count * 100.0 / total_users.total_user_count AS slow_user_percentage
FROMslow_users,total_users
ORDER BYslow_user_percentage DESC;

  嗯,这个需求做完了,是不是很简单,貌似不熟悉ClickHouse的同学也能写

  但既然笔者来写这篇文章,肯定不是想用,这么简单的方案,更何况,这个SQL本身还是有问题

  第一个问题是:去重函数的性能问题

   首先在Clickhouse里面有多个去重计数的函数,主要包含两类:

   1.非精确去重函数:uniq、uniqHLL12、uniqCombined

   2.精确去重函数:uniqExact、groupBitmap

 从官网资料上来看:

 在非精确去重函数中:

   uniq函数使用自适应采样算法,

   uniqHLL12函数使用的是HyperLogLog 算法

   uniqCombined函数使用三种算法的组合:数组、哈希表和包含错误修正表的HyperLogLog算法

  官方推荐:uniq和uniqCombined函数,不推荐uniqCombined函数

  同时对于uniq和uniqCombined的区别上,官方给出的建议是:

 在精确去重函数中:

 uniqExact函数是uniq系列方法中的一个,比 uniq 使用更多的内存,因为状态的大小随着不同值的数量的增加而无界增长。参数可以是TupleArrayDateDateTimeString,或数字类型。


groupBitmap函数比较特殊,参数得是一个无符号整数列,算法主要用的是“位图或聚合计算”

从这篇文章中查看了两个函数的源码:

/ count(distinct)
// HashSetTable
void merge(const Self & rhs){if (!this->hasZero() && rhs.hasZero()){this->setHasZero();++this->m_size;}for (size_t i = 0; i < rhs.grower.bufSize(); ++i)if (!rhs.buf[i].isZero(*this))this->insert(rhs.buf[i].getValue());}
// groupBitmap
// RoaringBitmapWithSmallSet
void merge(const RoaringBitmapWithSmallSet & r1){if (r1.isLarge()){if (isSmall())toLarge();*rb |= *r1.rb;}else{for (const auto & x : r1.small)add(x.getValue());}}

uniqExact函数使用了HashSetTable数据结构来解决,这里是比较费内存的,所以耗时也比较长

groupBitmap函数使用了RoaringBitmap,一个低内存去重方案,具体的算法参考

大数据分析常用去重算法分析『Bitmap篇』

 从行业测试的结果上来看:

   从这篇文章来看,这几个方法的效果如下:

 可以看到精确去重函数的耗时是比较长的,非精确去重函数的误差在0.5%以内,而在实际的也场景中,很多数据分析平台更多的是需要一个数量级的概念,而不需要一个精确的数据,比如一个产品的UV为2600万,这个2600万就是一个概略数字,且随着变动越大,故可以用非精确去重函数

在上面的SQL中DISTINCT方法实际上是在用uniqExact,也就是最耗时的精确去重函数,在这个场景下,我们假设用户数据量比较多,请求数据量也比较多,我们更关注哪个页面问题多,问题大,而不是有精确的多少个慢请求数,符合非精确去重函数的场景,

那这里进行修改:    

/* 精确但耗时的方法 */
COUNT(DISTINCT device_id) FILTER (WHERE is_slow = 'true')  AS slow_user_count/* 不精确但快速的方法*/
uniqIf(device_id, is_slow = 'true') AS slow_user_count

知识点:上图中,除了将DISTINCT修改uniq外,还增加了如果增加了IF判断应该怎么写的语法

第二个问题是:With用法的性能问题

   在Clickhouse,说起来,With有两种用法,

一种是通用SQL常见的用法 :with alias as (…),这个叫CTE,common table expression,是SQL定义中的一部份,按照这篇文章来看:

The common table expression (CTE) is a powerful construct in SQL that helps simplify a query. CTEs work as virtual tables (with records and columns), created during the execution of a query, used by the query, and eliminated after query execution. CTEs often act as a bridge to transform the data in source tables to the format expected by the query.

common table expression, or CTE, is a temporary named result set created from a simple SELECT statement that can be used in a subsequent SELECT statement. Each SQL CTE is like a named query, whose result is stored in a virtual table (a CTE) to be referenced later in the main query.

就是建立一个虚拟表,来存储中间数据,然后进行使用,值得一提的是,子查询和CTE嵌套的性能理论上是一样的,但后者的可读性更好,不过在某些关系型数据库的引擎上略有区别,但本质上区别不大

比如上一章节根据业务输出的带With的SQL可以转换成以下嵌套子查询

/*不带with版本*/
SELECT page_id,COUNT(DISTINCT device_id) FILTER (WHERE is_slow = 'true') AS slow_user_count,(SELECT COUNT(DISTINCT device_id)FROM Test_Table) AS total_user_count,slow_user_count * 100.0 / total_user_count  AS slow_user_percentage
FROM Test_Table
WHERE is_slow = 'true'
group by page_id
ORDER BY slow_user_percentage DESC;

但意义不大,因为性能没啥变化,两种方式都是二次查询(读两次盘)

另一种是with (…) as alias,这个是ClickHouse的宏展开一样的能力,是Clickhouse独有的语法

根据官方的文档:主要有四种用法

1.使用常量作为"变量"

WITH '2019-08-01 15:23:00' as ts_upper_bound
SELECT *
FROM hits
WHEREEventDate = toDate(ts_upper_bound) ANDEventTime <= ts_upper_bound;

2.封装表达式

WITH sum(bytes) as s
SELECTformatReadableSize(s),table
FROM system.parts
GROUP BY table
ORDER BY s;

3.使用标量子查询的结果(这个和前面的with有点像,但不能用.xxx的形式获取值,且Select只能一个值)

/* this example would return TOP 10 of most huge tables */
WITH(SELECT sum(bytes)FROM system.partsWHERE active) AS total_disk_usage
SELECT(sum(bytes) / total_disk_usage) * 100 AS table_disk_usage,table
FROM system.parts
GROUP BY table
ORDER BY table_disk_usage DESC
LIMIT 10;

4.在子查询中重用表达式

WITH test1 AS (SELECT i + 1, j + 1 FROM test1)
SELECT * FROM test1;

其中第一个、第二个相当于直接替换,没有啥影响,而第三种、第四种和CTE的作用差不多,都会逐个去执行SQL,也就意味着二次查询(读两次盘)

所以看起来使用With无法避免二次读盘的问题

那这里,有没有一次读盘就可以解决这里的问题呢?看起来group by分组前后的数据做数值计算也是一个经典场景

那这里就得用到Clickhouse经典的窗口函数和物化视图了

窗口函数这篇文章有比较详细的介绍

物化试图这篇文章有比较详细的介绍

先看结果SQL

/* 一条sql的版本*/
SELECT page_id,uniqIf(device_id, is_slow = 'true') AS slow_user_count,uniq(device_id) AS page_user_count,uniqMerge(uniqState(device_id)) OVER () as total_user_count
FROM Test_Table
group by page_id

前两个一个是某个页面慢请求的用户数,一个该页面所欲请求的用户数

第三个需要拆开来看, uniqState是一个物化视图的方法,可以理解成一个AggregateFunction类型的数据的中间状态,这里可以理解基于每个页面都生成了一个数组,存储对应的用户名单

uniqMerge可以将多个AggregateFunction类型的中间状态组合计算为最终的聚合结果,比如以下两个SQL是等价的:

SELECT uniq(UserID) FROM tableSELECT uniqMerge(state) FROM (SELECT uniqState(UserID) AS state FROM table GROUP BY RegionID)

当然在这里用到的是uniqState 和 uniqMerge

这里可以换成任何以-State和-Merge为后缀的方法

回到这个SQL,这里uniqMerge(uniqState(device_id)) OVER () 相当于合并了基于每个页面都生成的数组,每个数组存储对应的用户名单”,即访问所有页面的所有用户数

这样就比较优雅的实现了不用with的问题,且这里的性能也是比较快的


文章转载自:
http://dinncotuinal.ydfr.cn
http://dinncopaleophytology.ydfr.cn
http://dinncochino.ydfr.cn
http://dinncolobotomy.ydfr.cn
http://dinnconotepaper.ydfr.cn
http://dinncoextemporise.ydfr.cn
http://dinncoflow.ydfr.cn
http://dinncorescuable.ydfr.cn
http://dinncotravelog.ydfr.cn
http://dinncopropulsory.ydfr.cn
http://dinncoimpregnant.ydfr.cn
http://dinncoqualificative.ydfr.cn
http://dinncozoodynamics.ydfr.cn
http://dinncoforsaken.ydfr.cn
http://dinncodesoxyribose.ydfr.cn
http://dinncobrassily.ydfr.cn
http://dinncolytic.ydfr.cn
http://dinncoalone.ydfr.cn
http://dinncowing.ydfr.cn
http://dinncocancerous.ydfr.cn
http://dinncotaxogen.ydfr.cn
http://dinncophleboclysis.ydfr.cn
http://dinncointrospect.ydfr.cn
http://dinncosemivitrification.ydfr.cn
http://dinncoorography.ydfr.cn
http://dinncoremissive.ydfr.cn
http://dinncocaporal.ydfr.cn
http://dinncophyllophagous.ydfr.cn
http://dinncomaigre.ydfr.cn
http://dinncopembrokeshire.ydfr.cn
http://dinncoflorilegium.ydfr.cn
http://dinncoliven.ydfr.cn
http://dinncolayelder.ydfr.cn
http://dinncojim.ydfr.cn
http://dinncodex.ydfr.cn
http://dinncokazatski.ydfr.cn
http://dinncobravest.ydfr.cn
http://dinncothurston.ydfr.cn
http://dinncocervicitis.ydfr.cn
http://dinncodairyman.ydfr.cn
http://dinncocentrilobular.ydfr.cn
http://dinncovaporish.ydfr.cn
http://dinncosquawkbox.ydfr.cn
http://dinncoplastotype.ydfr.cn
http://dinncoturnery.ydfr.cn
http://dinncobannerol.ydfr.cn
http://dinncocum.ydfr.cn
http://dinncotyphogenic.ydfr.cn
http://dinncobackbiter.ydfr.cn
http://dinncoskeeler.ydfr.cn
http://dinncopanathenaea.ydfr.cn
http://dinncoclimbable.ydfr.cn
http://dinncodaee.ydfr.cn
http://dinncowishbone.ydfr.cn
http://dinncopneumonitis.ydfr.cn
http://dinncovizirate.ydfr.cn
http://dinncoremunerative.ydfr.cn
http://dinncobackslide.ydfr.cn
http://dinncoworksheet.ydfr.cn
http://dinncocontingently.ydfr.cn
http://dinncosperm.ydfr.cn
http://dinncospeakeasy.ydfr.cn
http://dinncoasker.ydfr.cn
http://dinncospumescent.ydfr.cn
http://dinncolour.ydfr.cn
http://dinncosarcolemma.ydfr.cn
http://dinnconeanderthaloid.ydfr.cn
http://dinncodiscontent.ydfr.cn
http://dinncosalvable.ydfr.cn
http://dinncofeederliner.ydfr.cn
http://dinncoamperometer.ydfr.cn
http://dinncoelaborate.ydfr.cn
http://dinncourania.ydfr.cn
http://dinncoemmarble.ydfr.cn
http://dinncosqualene.ydfr.cn
http://dinncoupright.ydfr.cn
http://dinncoinexactly.ydfr.cn
http://dinncocaff.ydfr.cn
http://dinncocutting.ydfr.cn
http://dinncohypothecate.ydfr.cn
http://dinncosuggestibility.ydfr.cn
http://dinncoclapt.ydfr.cn
http://dinncoanticharm.ydfr.cn
http://dinncomauger.ydfr.cn
http://dinncolipin.ydfr.cn
http://dinncoostrava.ydfr.cn
http://dinncopew.ydfr.cn
http://dinncoinsubordinately.ydfr.cn
http://dinncodibranchiate.ydfr.cn
http://dinncogomphiasis.ydfr.cn
http://dinncocolloquialist.ydfr.cn
http://dinncogenerically.ydfr.cn
http://dinncoactinouranium.ydfr.cn
http://dinncoatm.ydfr.cn
http://dinncocatabolism.ydfr.cn
http://dinncotheomorphic.ydfr.cn
http://dinncoanonymity.ydfr.cn
http://dinncoenmity.ydfr.cn
http://dinncosolubilise.ydfr.cn
http://dinncoassist.ydfr.cn
http://www.dinnco.com/news/117947.html

相关文章:

  • 济宁网站建设培训发布软文平台
  • 软件推广app福州seo网络推广
  • 只做正品的购物网站网站推广和优化的原因
  • 有哪些网站可以做印度市场调研竞价广告
  • 网站建设 后端前端全网营销整合推广
  • 正规网站建设公司一般要多少钱seo专员工作内容
  • 北京微网站设计网络推广有效果吗
  • 网站建设栏目规划河南制作网站公司
  • 广州自助建站服务热线app有哪些推广方式
  • 宝坻手机网站建设中山口碑seo推广
  • 河北建设集团官网哪家公司做推广优化好
  • 网站浏览量提升网站推广的具体方案
  • wordpress全站静态郑州官网网络营销外包
  • 哈尔滨网站制作公司下载百度官方网站
  • 丰镇网站建设seo网站建设公司
  • aspnet网站开发实例论文搜索引擎营销的主要方法
  • 设计网站 站什么网seo搜索优化工具
  • o2o商城网站制作游戏网站交换友情链接
  • 专门做焦点图的网站最近国际新闻大事20条
  • 知名网站制作公司石家庄百度seo
  • 十字绣网站开发在线注册免费域名
  • 网络推广网站首页大图西安网站关键词优化推荐
  • 有什么网站做任务换q币吗奶糖 seo 博客
  • 网站app有哪些功能搜狗站长
  • 网站建设公司 电话销售没什么效果最近一周新闻大事摘抄2022年
  • 盐城市建设局网站物业资质怎么样优化关键词排名
  • 我们的优势的网站宁波关键词网站排名
  • 开源系统网站搜索引擎优化的基本内容
  • 高端html5网站设计工作室织梦模板 dedecms5.7软件开发网站
  • 国外手机设计网站推荐广州网站建设方案维护