公司的治理體系是一套有效管理經(jīng)驗(yàn)集吟温,完全可以遷移到自己的生活中來荆针,以提升生活效率的碑宴。比如wiki...so殖属,我們來把wiki部署到自己的服務(wù)器上吧...其中涉及到Docker的知識(shí)比較多姐叁,可以參考上一篇文章...
準(zhǔn)備
- 一臺(tái)服務(wù)器(我用的阿里云)
- Docker
- PostgreSQL
- Confluence(破解)
開搞
安裝Docker
創(chuàng)建PostgreSQL
docker pull postgreSQL
拉下來官方postgreSQL鏡像
開啟指令
docker run -d postgres --name postgresdb -p 5432:5432 -e POSTGRES_PASSWORD=W****
參數(shù)說明
- 最簡(jiǎn)指令:
docker run postgres
直接運(yùn)行postgreSQL這個(gè)docker - 后臺(tái)執(zhí)行:
-d
- 給運(yùn)行的docker起個(gè)名字:
--name 名字
- 綁定docker端口號(hào)和主機(jī)端口號(hào):
-p 5432:5432
- 設(shè)置環(huán)境變量(environment variables):
-e POSTGRES_PASSWORD=數(shù)據(jù)庫密碼
運(yùn)行PostgresDB容器bash
docker exec -it postgresdb bash
參數(shù)說明
- 最簡(jiǎn)指令:
docker exec postgresdb bash
Usage: docker exec [OPTIONS] CONTAINER COMMAND [ARG...] - 說明:交互式容器進(jìn)程需要通過
-it
創(chuàng)建容器,這兩個(gè)參數(shù)洗显,讓docker client 即使和docker進(jìn)程之間沒有直接聯(lián)系外潜,也能獲取其stdin/stdout(標(biāo)準(zhǔn)輸入和輸出)-
-t
:創(chuàng)建一個(gè) pseudo-TTY,是client和容器進(jìn)程交換stdin/stdout的關(guān)鍵參考文章 -
-i
:Keep STDIN open even if not attached
-
操作數(shù)據(jù)庫
-
psql -U postgres
文檔-
psql
:PostgreSQL interactive terminal -
-U
:指定username
-
-
\l
:同\list
List the databases in the server and show their names, owners, character set encodings, and access privileges -
CREATE DATABASE confluence WITH OWNER postgres;
文檔 -
\q
:同\quit
Quits the psql program. In a script file, only execution of that script is terminated.
安裝Confluence
docker pull docker.io/cptactionhank/atlassian-confluence
拉CF...不過話說這樣拉速度好慢...兩個(gè)多小時(shí)還沒拉完...四個(gè)小時(shí)挠唆,拉完了...
啟動(dòng)CF
docker run -d --name confluence -p 8090:8090 --link postgresdb:db --user root:root cptactionhank/atlassian-confluence:latest
啟動(dòng)失敗...嘗試直接run处窥,發(fā)現(xiàn)報(bào)錯(cuò):內(nèi)存不夠...
然后...花了169塊大洋??把阿里云的內(nèi)存升到2G了...重啟,
service docker start
玄组,然后滔驾,跑起來了~
記一次數(shù)據(jù)庫容器崩潰及解決方案
之前部署PostgresSQL的時(shí)候,木有為數(shù)據(jù)庫綁定Volum...幸好做了CF級(jí)別的數(shù)據(jù)備份俄讹,不然所有文檔都?xì)Я?..
CF備份文件位置
PS. 使用上面提到的docker.io/cptactionhank/atlassian-confluence
image哆致,默認(rèn)做了Volume掛載,可以通過docker inspect confluence
指令Mount部分患膛,查看到掛載信息
"Mounts": [
{
"Name": "3af40009e8deb5427619b18e77a7395719579f2ee96bc057561214148829de62",
"Source": "/var/lib/docker/volumes/3af40009e8deb5427619b18e77a7395719579f2ee96bc057561214148829de62/_data",
"Destination": "/var/atlassian/confluence",
"Driver": "local",
"Mode": "",
"RW": true,
"Propagation": ""
},
{
"Name": "f6424969404e8a1124da31443babf01ac7460ad41fba7977ae2929e058f30b2b",
"Source": "/var/lib/docker/volumes/f6424969404e8a1124da31443babf01ac7460ad41fba7977ae2929e058f30b2b/_data",
"Destination": "/opt/atlassian/confluence/logs",
"Driver": "local",
"Mode": "",
"RW": true,
"Propagation": ""
}
],
我們可以看到沽瞭,CF容器的/var/atlassian/confluence
目錄,被掛載到了宿主機(jī)的/var/lib/docker/volumes/3af40009e8deb5427619b18e77a7395719579f2ee96bc057561214148829de62/_data/backup
目錄下
重啟postgresdb
這次重啟,需要做好容器磁盤的掛載驹溃,防止docker掛了導(dǎo)致數(shù)據(jù)丟失
docker run --name db -p 5432:5432 -e POSTGRES_PASSWORD=x****** -v /var/lib/docker/volumes/postgresql:/var/lib/pgsql/data -d postgres
- -v 指令:指定掛載路徑 城丧,格式為
宿主機(jī)路徑:容器目錄
參考
發(fā)現(xiàn)無法啟動(dòng)數(shù)據(jù)庫容器
使用docker logs postgresdb
查看報(bào)錯(cuò)原因
The files belonging to this database system will be owned by user "postgres".
This user must also own the server process.
The database cluster will be initialized with locale "en_US.utf8".
The default database encoding has accordingly been set to "UTF8".
The default text search configuration will be set to "english".
Data page checksums are disabled.
fixing permissions on existing directory /var/lib/postgresql/data ... ok
initdb: could not create directory "/var/lib/postgresql/data/pg_wal": No space left on device
initdb: removing contents of data directory "/var/lib/postgresql/data"
磁盤空間不足
聯(lián)想起前兩天阿里云發(fā)來的空間使用量超過95%的報(bào)警...
基本確定數(shù)據(jù)庫服務(wù)掛掉的原因 - 磁盤空間不足
解決方案
使用
-
df -h
查看掛載點(diǎn)的狀況 -
du -s -h ./*
查看當(dāng)前目錄文件大小
發(fā)現(xiàn)空間占用過多的,是cf的backup文件夾豌鹤,里面存放了近1年中亡哄,每一天的備份文件...尷尬...
刪除多余文件,配置自動(dòng)清理備份文件的指令
備份清理
參考
通過Cron定義自動(dòng)刪除老的備份文件的任務(wù)布疙,定期自動(dòng)運(yùn)行
vi /etc/cron.daily/deleteOldConfluenceBackups.cron
可以通過man find
查看find指令各參數(shù)相關(guān)說明
更新Confluence版本
發(fā)現(xiàn)時(shí)隔一年蚊惯,confluence已經(jīng)出了官方docker image了
拉鏡像:docker pull atlassian/confluence-server
跑起來:docker run -v /var/lib/docker/volumes/confluence:/var/atlassian/application-data/confluence --name="cf" -d -p 8090:8090 -p 8091:8091 --link db:db --user root:root --env CATALINA_CONNECTOR_PROXYNAME=wiki.daker.wang --env CATALINA_CONNECTOR_PROXYPORT=80 atlassian/confluence-server
云端把Docker中的文件拷到本地準(zhǔn)備破解:docker cp cf:/opt/atlassian/confluence/confluence/WEB-INF/lib/atlassian-extras-decoder-v2-3.4.1.jar ./
本地從云端取文件:scp ali-yun:/root/tmp/cf/atlassian-extras-decoder-v2-3.4.1.jar ~/Desktop
改名為:atlassian-extras-2.4.jar
下載:破解包
參考:破解步驟
重啟服務(wù):docker cf restart
然后進(jìn)去做配置就好了...嗯嗯...
Nginx 反向代理處配置
server {
listen 80;
server_name wiki.domain.com;
location / {
client_max_body_size 100m;
proxy_set_header X-Forwarded-Host $host;
proxy_set_header X-Forwarded-Server $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://HOST:PORT;
}
}
參考文檔
之后需要修改docker中的tomcat配置文件:/opt/atlassian/confluence/conf/server.xml
<Connector port="8090" scheme="http" proxyName="wiki.daker.wang" proxyPort="80" ...其他屬性... />
接著重啟tomcat就好
后記
2019.3.25
把wiki遷移到語雀上了...服務(wù)器上跑了點(diǎn)別的小東東,內(nèi)存老報(bào)警...
年齡大了灵临,不再癡迷「什么都自己做」了...能達(dá)成結(jié)果就好...