Ubuntu安装clickhouse数据库

目录

1、更新包列表

 2、运行安装脚本

3、设置密码

4、启动服务

5、测试连接

6、下载官方测试数据

        1、下载数据集直接执行以下代码

         2、创建数据库

        3、创建数据表(1)

        4、创建数据表(2)

        5、导入数据

7、测试查询

 8、远程连接


1、更新包列表

        sudo apt update

 2、运行安装脚本

sudo apt-get install -y apt-transport-https ca-certificates dirmngr
sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 8919F6BD2B48D754

echo "deb https://packages.clickhouse.com/deb stable main" | sudo tee \
    /etc/apt/sources.list.d/clickhouse.list
sudo apt-get update

sudo apt-get install -y clickhouse-server clickhouse-client

sudo service clickhouse-server start
clickhouse-client # or "clickhouse-client --password" if you've set up a password.

直接粘贴到终端上,使用shell工具如xshell

 

3、设置密码

 安装脚本会让你输入默认用户default的密码,我们可以直接回车不设置密码

安装成功 

4、启动服务

 sudo clickhouse-server restart

5、测试连接

 clickhouse-client -m

 -m参数是指开启多行输入,否则每次回车都会直接执行当前sql语句

--password xxx:如果有密码请加入此参数

 

6、下载官方测试数据

        1、下载数据集直接执行以下代码

curl https://datasets.clickhouse.com/hits/tsv/hits_v1.tsv.xz | unxz --threads=`nproc` > hits_v1.tsv
curl https://datasets.clickhouse.com/visits/tsv/visits_v1.tsv.xz | unxz --threads=`nproc` > visits_v1.tsv

         2、创建数据库

clickhouse-client --query "CREATE DATABASE IF NOT EXISTS tutorial"

        3、创建数据表(1)

CREATE TABLE tutorial.hits_v1
(
    `WatchID` UInt64,
    `JavaEnable` UInt8,
    `Title` String,
    `GoodEvent` Int16,
    `EventTime` DateTime,
    `EventDate` Date,
    `CounterID` UInt32,
    `ClientIP` UInt32,
    `ClientIP6` FixedString(16),
    `RegionID` UInt32,
    `UserID` UInt64,
    `CounterClass` Int8,
    `OS` UInt8,
    `UserAgent` UInt8,
    `URL` String,
    `Referer` String,
    `URLDomain` String,
    `RefererDomain` String,
    `Refresh` UInt8,
    `IsRobot` UInt8,
    `RefererCategories` Array(UInt16),
    `URLCategories` Array(UInt16),
    `URLRegions` Array(UInt32),
    `RefererRegions` Array(UInt32),
    `ResolutionWidth` UInt16,
    `ResolutionHeight` UInt16,
    `ResolutionDepth` UInt8,
    `FlashMajor` UInt8,
    `FlashMinor` UInt8,
    `FlashMinor2` String,
    `NetMajor` UInt8,
    `NetMinor` UInt8,
    `UserAgentMajor` UInt16,
    `UserAgentMinor` FixedString(2),
    `CookieEnable` UInt8,
    `JavascriptEnable` UInt8,
    `IsMobile` UInt8,
    `MobilePhone` UInt8,
    `MobilePhoneModel` String,
    `Params` String,
    `IPNetworkID` UInt32,
    `TraficSourceID` Int8,
    `SearchEngineID` UInt16,
    `SearchPhrase` String,
    `AdvEngineID` UInt8,
    `IsArtifical` UInt8,
    `WindowClientWidth` UInt16,
    `WindowClientHeight` UInt16,
    `ClientTimeZone` Int16,
    `ClientEventTime` DateTime,
    `SilverlightVersion1` UInt8,
    `SilverlightVersion2` UInt8,
    `SilverlightVersion3` UInt32,
    `SilverlightVersion4` UInt16,
    `PageCharset` String,
    `CodeVersion` UInt32,
    `IsLink` UInt8,
    `IsDownload` UInt8,
    `IsNotBounce` UInt8,
    `FUniqID` UInt64,
    `HID` UInt32,
    `IsOldCounter` UInt8,
    `IsEvent` UInt8,
    `IsParameter` UInt8,
    `DontCountHits` UInt8,
    `WithHash` UInt8,
    `HitColor` FixedString(1),
    `UTCEventTime` DateTime,
    `Age` UInt8,
    `Sex` UInt8,
    `Income` UInt8,
    `Interests` UInt16,
    `Robotness` UInt8,
    `GeneralInterests` Array(UInt16),
    `RemoteIP` UInt32,
    `RemoteIP6` FixedString(16),
    `WindowName` Int32,
    `OpenerName` Int32,
    `HistoryLength` Int16,
    `BrowserLanguage` FixedString(2),
    `BrowserCountry` FixedString(2),
    `SocialNetwork` String,
    `SocialAction` String,
    `HTTPError` UInt16,
    `SendTiming` Int32,
    `DNSTiming` Int32,
    `ConnectTiming` Int32,
    `ResponseStartTiming` Int32,
    `ResponseEndTiming` Int32,
    `FetchTiming` Int32,
    `RedirectTiming` Int32,
    `DOMInteractiveTiming` Int32,
    `DOMContentLoadedTiming` Int32,
    `DOMCompleteTiming` Int32,
    `LoadEventStartTiming` Int32,
    `LoadEventEndTiming` Int32,
    `NSToDOMContentLoadedTiming` Int32,
    `FirstPaintTiming` Int32,
    `RedirectCount` Int8,
    `SocialSourceNetworkID` UInt8,
    `SocialSourcePage` String,
    `ParamPrice` Int64,
    `ParamOrderID` String,
    `ParamCurrency` FixedString(3),
    `ParamCurrencyID` UInt16,
    `GoalsReached` Array(UInt32),
    `OpenstatServiceName` String,
    `OpenstatCampaignID` String,
    `OpenstatAdID` String,
    `OpenstatSourceID` String,
    `UTMSource` String,
    `UTMMedium` String,
    `UTMCampaign` String,
    `UTMContent` String,
    `UTMTerm` String,
    `FromTag` String,
    `HasGCLID` UInt8,
    `RefererHash` UInt64,
    `URLHash` UInt64,
    `CLID` UInt32,
    `YCLID` UInt64,
    `ShareService` String,
    `ShareURL` String,
    `ShareTitle` String,
    `ParsedParams` Nested(
        Key1 String,
        Key2 String,
        Key3 String,
        Key4 String,
        Key5 String,
        ValueDouble Float64),
    `IslandID` FixedString(16),
    `RequestNum` UInt32,
    `RequestTry` UInt8
)
ENGINE = MergeTree()
PARTITION BY toYYYYMM(EventDate)
ORDER BY (CounterID, EventDate, intHash32(UserID))
SAMPLE BY intHash32(UserID)

        4、创建数据表(2)

CREATE TABLE tutorial.visits_v1
(
    `CounterID` UInt32,
    `StartDate` Date,
    `Sign` Int8,
    `IsNew` UInt8,
    `VisitID` UInt64,
    `UserID` UInt64,
    `StartTime` DateTime,
    `Duration` UInt32,
    `UTCStartTime` DateTime,
    `PageViews` Int32,
    `Hits` Int32,
    `IsBounce` UInt8,
    `Referer` String,
    `StartURL` String,
    `RefererDomain` String,
    `StartURLDomain` String,
    `EndURL` String,
    `LinkURL` String,
    `IsDownload` UInt8,
    `TraficSourceID` Int8,
    `SearchEngineID` UInt16,
    `SearchPhrase` String,
    `AdvEngineID` UInt8,
    `PlaceID` Int32,
    `RefererCategories` Array(UInt16),
    `URLCategories` Array(UInt16),
    `URLRegions` Array(UInt32),
    `RefererRegions` Array(UInt32),
    `IsYandex` UInt8,
    `GoalReachesDepth` Int32,
    `GoalReachesURL` Int32,
    `GoalReachesAny` Int32,
    `SocialSourceNetworkID` UInt8,
    `SocialSourcePage` String,
    `MobilePhoneModel` String,
    `ClientEventTime` DateTime,
    `RegionID` UInt32,
    `ClientIP` UInt32,
    `ClientIP6` FixedString(16),
    `RemoteIP` UInt32,
    `RemoteIP6` FixedString(16),
    `IPNetworkID` UInt32,
    `SilverlightVersion3` UInt32,
    `CodeVersion` UInt32,
    `ResolutionWidth` UInt16,
    `ResolutionHeight` UInt16,
    `UserAgentMajor` UInt16,
    `UserAgentMinor` UInt16,
    `WindowClientWidth` UInt16,
    `WindowClientHeight` UInt16,
    `SilverlightVersion2` UInt8,
    `SilverlightVersion4` UInt16,
    `FlashVersion3` UInt16,
    `FlashVersion4` UInt16,
    `ClientTimeZone` Int16,
    `OS` UInt8,
    `UserAgent` UInt8,
    `ResolutionDepth` UInt8,
    `FlashMajor` UInt8,
    `FlashMinor` UInt8,
    `NetMajor` UInt8,
    `NetMinor` UInt8,
    `MobilePhone` UInt8,
    `SilverlightVersion1` UInt8,
    `Age` UInt8,
    `Sex` UInt8,
    `Income` UInt8,
    `JavaEnable` UInt8,
    `CookieEnable` UInt8,
    `JavascriptEnable` UInt8,
    `IsMobile` UInt8,
    `BrowserLanguage` UInt16,
    `BrowserCountry` UInt16,
    `Interests` UInt16,
    `Robotness` UInt8,
    `GeneralInterests` Array(UInt16),
    `Params` Array(String),
    `Goals` Nested(
        ID UInt32,
        Serial UInt32,
        EventTime DateTime,
        Price Int64,
        OrderID String,
        CurrencyID UInt32),
    `WatchIDs` Array(UInt64),
    `ParamSumPrice` Int64,
    `ParamCurrency` FixedString(3),
    `ParamCurrencyID` UInt16,
    `ClickLogID` UInt64,
    `ClickEventID` Int32,
    `ClickGoodEvent` Int32,
    `ClickEventTime` DateTime,
    `ClickPriorityID` Int32,
    `ClickPhraseID` Int32,
    `ClickPageID` Int32,
    `ClickPlaceID` Int32,
    `ClickTypeID` Int32,
    `ClickResourceID` Int32,
    `ClickCost` UInt32,
    `ClickClientIP` UInt32,
    `ClickDomainID` UInt32,
    `ClickURL` String,
    `ClickAttempt` UInt8,
    `ClickOrderID` UInt32,
    `ClickBannerID` UInt32,
    `ClickMarketCategoryID` UInt32,
    `ClickMarketPP` UInt32,
    `ClickMarketCategoryName` String,
    `ClickMarketPPName` String,
    `ClickAWAPSCampaignName` String,
    `ClickPageName` String,
    `ClickTargetType` UInt16,
    `ClickTargetPhraseID` UInt64,
    `ClickContextType` UInt8,
    `ClickSelectType` Int8,
    `ClickOptions` String,
    `ClickGroupBannerID` Int32,
    `OpenstatServiceName` String,
    `OpenstatCampaignID` String,
    `OpenstatAdID` String,
    `OpenstatSourceID` String,
    `UTMSource` String,
    `UTMMedium` String,
    `UTMCampaign` String,
    `UTMContent` String,
    `UTMTerm` String,
    `FromTag` String,
    `HasGCLID` UInt8,
    `FirstVisit` DateTime,
    `PredLastVisit` Date,
    `LastVisit` Date,
    `TotalVisits` UInt32,
    `TraficSource` Nested(
        ID Int8,
        SearchEngineID UInt16,
        AdvEngineID UInt8,
        PlaceID UInt16,
        SocialSourceNetworkID UInt8,
        Domain String,
        SearchPhrase String,
        SocialSourcePage String),
    `Attendance` FixedString(16),
    `CLID` UInt32,
    `YCLID` UInt64,
    `NormalizedRefererHash` UInt64,
    `SearchPhraseHash` UInt64,
    `RefererDomainHash` UInt64,
    `NormalizedStartURLHash` UInt64,
    `StartURLDomainHash` UInt64,
    `NormalizedEndURLHash` UInt64,
    `TopLevelDomain` UInt64,
    `URLScheme` UInt64,
    `OpenstatServiceNameHash` UInt64,
    `OpenstatCampaignIDHash` UInt64,
    `OpenstatAdIDHash` UInt64,
    `OpenstatSourceIDHash` UInt64,
    `UTMSourceHash` UInt64,
    `UTMMediumHash` UInt64,
    `UTMCampaignHash` UInt64,
    `UTMContentHash` UInt64,
    `UTMTermHash` UInt64,
    `FromHash` UInt64,
    `WebVisorEnabled` UInt8,
    `WebVisorActivity` UInt32,
    `ParsedParams` Nested(
        Key1 String,
        Key2 String,
        Key3 String,
        Key4 String,
        Key5 String,
        ValueDouble Float64),
    `Market` Nested(
        Type UInt8,
        GoalID UInt32,
        OrderID String,
        OrderPrice Int64,
        PP UInt32,
        DirectPlaceID UInt32,
        DirectOrderID UInt32,
        DirectBannerID UInt32,
        GoodID String,
        GoodName String,
        GoodQuantity Int32,
        GoodPrice Int64),
    `IslandID` FixedString(16)
)
ENGINE = CollapsingMergeTree(Sign)
PARTITION BY toYYYYMM(StartDate)
ORDER BY (CounterID, StartDate, intHash32(UserID), VisitID)
SAMPLE BY intHash32(UserID)

        5、导入数据

将刚才下载的两个数据集导入

clickhouse-client --query "INSERT INTO tutorial.hits_v1 FORMAT TSV" --max_insert_block_size=100000 < hits_v1.tsv
clickhouse-client --query "INSERT INTO tutorial.visits_v1 FORMAT TSV" --max_insert_block_size=100000 < visits_v1.tsv

7、测试查询

SELECT
    StartURL AS URL,
    AVG(Duration) AS AvgDuration
FROM tutorial.visits_v1
WHERE StartDate BETWEEN '2014-03-23' AND '2014-03-30'
GROUP BY URL
ORDER BY AvgDuration DESC
LIMIT 10

 8、远程连接

1、修改本地配置

nano /etc/clickhouse-server/config.xml

2、把注释掉的<listen_host>::</listen_host>取消注释,然后重启服务

service clickhouse-server restart 
  • 4
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 麒麟安装ClickHouse可以按照以下步骤进行: 第一步,获取ClickHouse安装包。可以在ClickHouse官方网站上下载最新版本的ClickHouse安装包。 第二步,安装依赖包。在麒麟系统中,需要安装一些依赖包,以便能够顺利进行ClickHouse安装。可以使用以下命令安装依赖包: sudo apt-get install lsb-release apt-transport-https ca-certificates dirmngr -y 第三步,添加ClickHouse的软件源。可以使用以下命令将ClickHouse的软件源添加到系统中: echo "deb http://repo.yandex.ru/clickhouse/deb/stable/ main/" | sudo tee /etc/apt/sources.list.d/clickhouse.list 第四步,导入ClickHouse的公钥。可以使用以下命令导入ClickHouse的公钥: sudo apt-key adv --keyserver keyserver.ubuntu.com --recv E0C56BD4 第五步,更新软件包列表。可以使用以下命令更新系统的软件包列表: sudo apt-get update 第六步,安装ClickHouse。可以使用以下命令安装ClickHouse: sudo apt-get install clickhouse-server clickhouse-client -y 第七步,启动ClickHouse服务。可以使用以下命令启动ClickHouse服务: sudo service clickhouse-server start 安装完成后,可以使用clickhouse-client命令连接到ClickHouse服务器,并进行数据访问和管理。 ### 回答2: 麒麟是中国自主研发的操作系统,是国内最大的Linux发行版之一。clickhouse是一个开源的列式数据库管理系统,专门用于处理大规模数据分析工作。下面是如何在麒麟中安装clickhouse的步骤: 1. 从clickhouse官方网站下载适用于麒麟的二进制包。你可以在clickhouse官方网站的下载页面找到适合你系统版本的二进制包。 2. 解压下载的二进制包。使用终端进入到解压后的clickhouse目录,并将其拷贝到合适的位置。例如,可以将clickhouse目录拷贝到/usr/local/目录下。 3. 创建clickhouse用户和组。使用以下命令创建clickhouse用户和组: ``` sudo groupadd clickhouse sudo useradd -g clickhouse clickhouse ``` 4. 设置clickhouse数据目录权限。使用以下命令设置clickhouse数据目录的权限: ``` sudo chown -R clickhouse:clickhouse /var/lib/clickhouse ``` 5. 设置clickhouse服务。使用以下命令设置clickhouse服务: ``` sudo cp clickhouse-server/etc/clickhouse-server/config.xml /etc/clickhouse-server/config.xml sudo cp clickhouse-server/etc/logrotate.d/clickhouse-server /etc/logrotate.d/clickhouse-server sudo sed -i 's,<!-- <listen>127.0.0.2:9000<\/listen> -->,<listen>0.0.0.0:9000<\/listen>,' /etc/clickhouse-server/config.xml sudo systemctl enable clickhouse-server sudo systemctl start clickhouse-server ``` 6. 进行安全设置。使用以下命令设置clickhouse的安全性: ``` clickhouse-server/bin/clickhouse user modify --password "your_password" --name default clickhouse-server/bin/clickhouse-client --password your_password --query "CREATE DATABASE your_database" ``` 7. 验证安装。使用以下命令验证clickhouse是否成功安装: ``` clickhouse-server/bin/clickhouse-client --password your_password --query "SHOW DATABASES" ``` 如果一切顺利,你应该能够看到clickhouse成功安装在你的麒麟系统中。 这就是在麒麟操作系统中安装clickhouse的步骤。希望对你有帮助! ### 回答3: 麒麟是中国自主研发的操作系统,而ClickHouse是俄罗斯Yandex公司开发的一种高性能列存数据库管理系统。要在麒麟系统上安装ClickHouse,可以按照以下步骤进行操作: 1. 在网上下载ClickHouse安装包,可以选择稳定版本或者最新版本,下载后将安装包保存到本地磁盘。 2. 使用终端或者命令行界面登录到麒麟系统。 3. 解压安装包,可以使用命令`tar -xvf clickhouse.tar.gz`进行解压。解压后会得到一个clickhouse文件夹。 4. 进入clickhouse文件夹,使用命令`cd clickhouse`。 5. 在命令行中输入`sudo ./install.sh`,然后按Enter键执行安装脚本。根据提示输入管理员密码。 6. 等待安装完成,期间可能需要下载和安装一些依赖包。安装完成后,会在系统中创建ClickHouse服务。 7. 启动ClickHouse服务,可以使用命令`sudo service clickhouse-server start`。启动后,可以使用命令`sudo service clickhouse-server status`来检查服务的状态。 8. 如果需要设置ClickHouse服务开机自启动,可以使用命令`sudo systemctl enable clickhouse-server`。 9. 使用web浏览器打开ClickHouse的Web界面,默认地址是http://localhost:8123。可以在浏览器中输入该地址,然后按Enter键进入。 10. 在Web界面中可以进行ClickHouse数据库的配置和管理,包括创建数据库、创建数据表、插入数据、查询数据等操作。 通过以上步骤,你就可以在麒麟系统上成功安装和配置ClickHouse数据库了。安装完成后,你可以根据需要进行定制和优化,以满足你的具体需求。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值