下載鏡像
docker pull cloudera/quickstart
// 或者在 cloudera 官網(wǎng)下載文件后使用 `docker import` 命令導入
// https://downloads.cloudera.com/demo_vm/docker/cloudera-quickstart-vm-5.13.0-0-beta-docker.tar.gz
添加 hosts
quickstart.cloudera 指向宿主機的 IP
vim /etc/hosts
xx.xx.xx.xx quickstart.cloudera
啟動服務(宿主機要求 8G 內(nèi)存)
docker run -d --name cdh --hostname=quickstart.cloudera --privileged=true -p 8020:8020 -p 8022:8022 -p 7180:7180 -p 21050:21050 -p 50070:50070 -p 50075:50075 -p 50010:50010 -p 50020:50020 -p 8890:8890 -p 60010:60010 -p 10002:10002 -p 25010:25010 -p 25020:25020 -p 18088:18088 -p 8088:8088 -p 19888:19888 -p 7187:7187 -p 11000:11000 -p 8888:8888 -p 2181:2181 -p 10000:10000 cloudera/quickstart /bin/bash -c '/usr/bin/docker-quickstart && /home/cloudera/cloudera-manager --express --force && service ntpd start && tail -F /var/log/*.log'
等待幾分鐘后,打開
http://quickstart.cloudera:7180
用戶名密碼均為 cloudera

在網(wǎng)頁上啟動 HFDS Hive Yarn zookeeper Hue 這些服務
等待全部啟動完成后,打開
http://quickstart.cloudera:8888
用戶名密碼均為 cloudera

在這里就可以方便的查看 hdfs 文件以及通過 hive 查詢數(shù)據(jù)了
HDFS UI: http://quickstart.cloudera:8888/filebrowser/
Hive UI: http://quickstart.cloudera:8888/beeswax/
使用 python 讀寫 hdfs 示例
編輯待上傳的示例文件:
data1.csv
user_id,name,sex,age
10001,張三,1,20
10002,李四,0,18
10003,王五,1,27
10004,趙六,1,33
data2.csv
user_id,fans_id,time
10001,10002,2019-10-01
10001,10003,2019-11-03
10002,10003,2019-10-22
10002,10004,2019-11-02
10003,10001,2019-09-13
10004,10001,2019-09-08
10004,10002,2019-10-08
10004,10003,2019-11-15
安裝 hdfs 模塊
pip install hdfs
python 腳本
import hdfs
client = hdfs.InsecureClient('http://quickstart.cloudera:50070', user='cloudera')
# 瀏覽目錄
print(client.list('/'))
# 創(chuàng)建目錄
client.makedirs('/user/cloudera/users')
client.makedirs('/user/cloudera/fans')
# 上傳文件
client.upload('/user/cloudera/users/data.csv', './data1.csv', overwrite=True)
client.upload('/user/cloudera/fans/data.csv', './data2.csv', overwrite=True)
print('upload success!')
# 讀取 hdfs 文件內(nèi)容
with client.read('/user/cloudera/users/data.csv') as r:
print(r.read())
Hive 操作示例
打開頁面 http://quickstart.cloudera:8888/beeswax/
輸入腳本創(chuàng)建外部表
create external table users
(user_id int, name string, sex int, age int)
ROW FORMAT DELIMITED
FIELDS TERMINATED BY ','
STORED AS TEXTFILE
location '/user/cloudera/users'
tblproperties("skip.header.line.count"="1");
create external table fans
(user_id int, fans_id int, time string)
ROW FORMAT DELIMITED
FIELDS TERMINATED BY ','
STORED AS TEXTFILE
location '/user/cloudera/fans'
tblproperties("skip.header.line.count"="1");
點擊 執(zhí)行 按鈕,完成表創(chuàng)建
再輸入查詢腳本
SELECT name, count(*) AS fans_count
FROM users
LEFT JOIN fans
ON fans.user_id = users.user_id
GROUP BY name;
點擊 執(zhí)行 按鈕,等待一段時間后查看到統(tǒng)計結果

使用 python 進行 hive 查詢
安裝 PyHive模塊
apt-get install libsasl2-dev -y
pip install sasl
pip install thrift
pip install thrift-sasl
pip install PyHive
python 腳本
from pyhive import hive
conn = hive.Connection(host='quickstart.cloudera', port=10000, username='cloudera', database='default')
cursor = conn.cursor()
cursor.execute('select * from users;')
print(cursor.fetchall())
cursor.execute('select count(*) from users;')
print(cursor.fetchone())
cursor.close()
conn.close()