# mongod2.6升級3.0及優化方案
先把大概步驟寫出來,背景和細節后續補充
## 升級副本集的步驟為:
1.master節點執行命令從集群中剔除需要升級的副本節點
```
goumin:PRIMARY> rs.remove("192.168.56.202:27017")
```
2.剔除后在副本機器上停止mongo服務
```
/etc/init.d/mongodb stop
```
3.修改配置文件,去掉集群的配置
```
vim /usr/local/mongodb/conf/mongo.conf
```
4.重新啟動副本節點的mongo服務,驗證升級條件是否允許
/etc/init.d/mongodb start
```
>use admin
>db.upgradeCheckAllDBs()
```
如果最后返回true就是滿足升級的要求
5.檢測通過后停止mongo服務使用
```
/etc/init.d/mongodb stop
killall mongod
```
6.使用3.0的bin文件替換2.0的bin文件
```
wget http://downloads.mongodb.org/linux/mongodb-linux-x86_64-v3.0-latest.tgz
tar zxf mongodb-linux-x86_64-v3.0-latest.tgz
\cp -a mongodb-linux-x86_64-3.0.15-19-gb4172b9/bin/* /usr/local/mongodb/bin/
```
6.重新啟動Mongo查看是否正常
```
/etc/init.d/mongodb start
```
7.關閉mongo服務,修改配置文件新的引擎和新的數據目錄
```
/etc/init.d/mongodb stop
mkdir /data/mongov3
chown -R mongodb:mongodb /data/mongov3/
```
修改配置文件引擎為wiredTiger并且將數據目錄修改為新的目錄
```
[root@mongodb-202 ~]# cat /usr/local/mongodb/conf/mongo.conf
##3.0數據目錄
dbpath = /data/mongov3
##日志目錄
logpath = /usr/local/mongodb/logs/mongodb.log
##守護模式
fork=true
##pid file
pidfilepath=/var/run/mongod.pid
##socket
bind_ip=0.0.0.0
## no password
noauth=true
oplogSize = 2048
#副本參數
replSet = vim26/172.16.1.202 :27017
#使用wiredTiger引擎
storageEngine=wiredTiger
```
8.重新啟動副本的Mongo,并在主節點執行命令加入集群
```
goumin:PRIMARY> rs.add("192.168.56.202:27017");
```
9.驗證寫入寫入數據同步是否正常
主庫操作寫入測試數據
```
goumin:PRIMARY> for(var i=0;i<10000;i++)db.d.insert({uid:i,uname:'osqlfan'+i});
WriteResult({ "nInserted" : 1 })
```
查看剛才寫入的數據
```
goumin:PRIMARY> db.d.find().count();
10000
```
副本操作,查看是否有剛才同步的數據,如果有,則同步正常
```
goumin:SECONDARY> db.d.find().count();
10000
```
10.相同操作完成所有副本
```
#主庫操作
rs.remove("192.168.56.201:27017")
#副本操作關閉數據庫
/etc/init.d/mongodb stop
#修改副本的配置文件,注釋復制語句
sed -i 's@replSet@#replSet@' /usr/local/mongodb/conf/mongo.conf
#啟動mongo服務,驗證升級條件是否允許
/etc/init.d/mongodb start
>use admin
>db.upgradeCheckAllDBs()
#停止mongo服務,殺掉mongod進程
/etc/init.d/mongodb stop
killall mongod
#復制3.0的bin文件替換2.6
\cp -a mongodb-linux-x86_64-3.0.15-19-gb4172b9/bin/* /usr/local/mongodb/bin/
#恢復配置文件,添加引擎文件以及修改數據目錄配置
[root@mongodb-201 ~]# egrep "wiredTiger|dbpath" /usr/local/mongodb/conf/mongo.conf
dbpath = /data/mongov3
storageEngine=wiredTiger
#創建新的數據目錄
mkdir /data/mongov3
chown -R mongodb:mongodb /data/mongov3/
#重新啟動mongo服務
/etc/init.d/mongodb start
#重新加入集群
goumin:PRIMARY> rs.add("192.168.56.201:27017");
{ "down" : [ "192.168.56.201:27017" ], "ok" : 1 }
#寫入數據檢查是否正常
```
11.副本升級完成后將master進行降級
主庫進行降級
```
goumin:PRIMARY> rs.stepDown()
```
集群新主庫刪除主庫的節點
```
rs.remove("192.168.56.201:27017")
```
剩下的操作和從庫一樣
#參數調優
## 升級3.0后提示的警告
```
2017-12-11T13:05:46.336+0800 I CONTROL [initandlisten] ** WARNING: You are running this process as the root user, which is not recommended.
2017-12-11T13:05:46.336+0800 I CONTROL [initandlisten]
2017-12-11T13:05:46.337+0800 I CONTROL [initandlisten]
2017-12-11T13:05:46.337+0800 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.
2017-12-11T13:05:46.337+0800 I CONTROL [initandlisten] ** We suggest setting it to 'never'
2017-12-11T13:05:46.337+0800 I CONTROL [initandlisten]
2017-12-11T13:05:46.337+0800 I CONTROL [initandlisten] ** WARNING: soft rlimits too low. rlimits set to 7976 processes, 65536 files. Number of processes should be at least 32768 : 0.5 times number of files.
2017-12-08T06:20:07.343+0800 [initandlisten] ** WARNING: You are running on a NUMA machine.
2017-12-08T06:20:07.343+0800 [initandlisten] ** We suggest launching mongod like this to avoid performance problems:
2017-12-08T06:20:07.343+0800 [initandlisten] ** numactl --interleave=all mongod [other options]
```
## 針對警告進行優化
1.如果條件允許的話,建議重新格式化磁盤為xfs格式
```
apt-get install xfsprogs
mkfs.xfs /dev/sdb
mount -t xfs /dev/sdb /data/
```
2.優化大內存頁
```
echo "never" > /sys/kernel/mm/transparent_hugepage/enabled
echo "never" > /sys/kernel/mm/transparent_hugepage/defrag
```
4.優化連接數
```
vim /etc/profile
ulimit -f unlimited
ulimit -t unlimited
ulimit -v unlimited
ulimit -n 64000
ulimit -m unlimited
ulimit -u 32000
```
5.關閉numa
- 安裝numactl
```
apt-get install numactl
```
- 執行下面2條命令
```
echo > /proc/sys/vm/zone_reclaim_mode
sysctl -w vm.zone_reclaim_mode=0
```
- 修改啟動命令,可以在啟動腳本里更改
```
numactl --interleave=all /usr/local/mongodb/bin/mongod -f /usr/local/mongodb/conf/mongo.conf
```
# mongo相關博客地址
非常全面的dba博客
http://blog.csdn.net/mchdba/article/category/1381536
mongodb2.6 replSet 升級到 mongodb3.0
http://blog.csdn.net/zhaowenzhong/article/details/50593363
官方對于numa的介紹和解決辦法
https://docs.mongodb.com/manual/administration/production-notes/#production-numa
官方對于ulimit的介紹
https://docs.mongodb.com/manual/reference/ulimit/
官方升級3.0的介紹
https://docs.mongodb.com/manual/release-notes/3.0-upgrade/
mongodb關于ulimit優化操作
http://www.cppblog.com/changshoumeng/archive/2015/04/13/210327.html
- 運維筆記
- 零: 安裝部署篇
- Zabbix
- HAproxy
- Nginx
- Apache
- Tomcat
- Mysql
- Redis
- ELK
- MongoDB
- hadoop
- GIt
- JDK
- Docker
- OpenVPN
- iRedMail
- GitLab
- ESXi
- Jenkins
- NFS
- rsync
- Python
- Keepalived
- 軟件打包篇
- 私有倉庫篇
- kafka
- zookeeper
- Spark
- Linux基礎篇
- 1.1 Linux系統介紹
- 1.3 系統優化
- 1.4 問題總結
- Linux核心命令
- 聲明
- 1-文件和目錄操作命令
- 1.3 tree: 以樹形結構顯示目錄下的內容
- 2-文件過濾及內容編輯處理命令
- find:查找目錄下的文件
- 3-文本處理三劍客
- 4-Linux信息顯示與搜索文件命令
- du:統計磁盤空間使用情況
- 5-文件備份與壓縮命令
- rsync:文件同步工具
- 6-Linux用戶管理及用戶信息查詢命令
- 7-Linux磁盤與文件系統管理命令
- 8-Linux進程管理命令
- 9-Linux網絡管理命令
- 10-Linux系統管理命令
- 11-Linux系統常用內置命令
- 服務相關
- Nginx
- 安裝部署
- 文件路徑說明
- 服務啟動管理
- 配置文件說明
- json格式日志的配置文件
- https代理
- nginx負載均衡代理websocket
- 服務優化
- 維護腳本
- 問題總結
- rewrite帶?跳轉
- nginx查看默認安裝的模塊
- HAproxy
- 2.2.1 安裝部署
- 2.2.2 文件路徑說明
- 2.2.3 服務啟動管理
- 2.2.4 配置文件說明
- ha代理websocket
- 2.2.5 集群高可用
- 2.2.6 服務優化
- 2.2.7 維護腳本
- 2.2.8 問題總結
- PHP
- 2.3.1 安裝部署
- keepalived
- 配置文件注釋
- 配置多組VIP
- Java
- 安裝部署java
- ansible部署java
- supervisor
- supervisor安裝部署測試
- iptables
- CentOS7安裝配置iptables
- pm2相關
- kafka相關
- kafka和zookeeper集群安裝部署
- nodejs
- 安裝部署nodejs
- sersync
- sersync備份圖片服務
- gitlab相關
- gitlab安裝部署
- gitlab強制修改密碼
- gitlab不同的連接方式
- jenkins相關
- 安裝部署jenkins
- python相關
- python虛擬環境
- debian安裝pyhton3.6
- Turnserver服務器搭建
- NFS相關
- 固定NFS和rsync端口
- go相關
- 安裝go
- maven相關
- debian私有倉庫搭建
- 翻墻
- linux下的百度云盤
- 私有網盤owncloud部署
- crontab定時任務
- 數據庫相關
- mongodb
- 重用操作命令
- 副本集配置文件
- 慢查詢設置
- 數據備份恢復以及數據導入導出
- 從庫允許只讀設置
- redis
- redis單節點安裝部署
- 配置文件注釋
- redis分析工具rdbtools使用
- redis數據導入導出集群工具
- redis內存信息解釋
- redis警告優化
- PHP會話session保存到redis集群
- redis啟動關閉腳本
- elk相關
- elastersearch常用命令
- elasticsearch6所需配置文件
- elasticsearch6的head插件安裝
- elk6安裝腳本
- filebeat收集php日志多行轉換
- filebeat自定義index
- elk-dockercompes配置
- docker部署elk收集runtime日志
- elasticsearch6添加新節點報錯
- elasticsearch查看索引
- docker部署es+filebeat+kibana
- mysql相關
- mysql日志
- mysql密碼過期
- mysql用戶授權訪問庫
- mysql安裝部署
- MariaDB安裝部署
- 大數據相關
- hadoop相關
- Ambari2.6離線安裝hadoop
- Ambari安裝出現的問題
- 檢測hadoop當前運行了哪些服務端口腳本
- 監控相關
- CentOS7安裝Zabbix3.4
- docker安裝zabbix
- 運維腳本
- 根據配置文件檢查服務端口運行狀態
- nginx日志分析
- ngixn日志合并腳本
- nginx查詢關鍵鏈接響應時間
- 圖片同步腳本
- 批量獲取iptables設置的端口然后驗證本機端口是否存活
- 按日期統計不同接口的響應時間
- php進程假死狀態定時清理
- 運維自動化
- deb打包命令
- ansible相關
- ansible部署
- ansible配置推送
- 編程語言
- 1-SHELL
- 2-Python
- 3-GO
- 有趣的工具
- vim
- 聲明
- 第1章: Vim解決問題的方式
- 技巧1-認識 . 命令
- 技巧2-不要自我重復
- 技巧3-以進為退
- 技巧4-執行,重復,回退
- 技巧5-查找并手動替換
- 技巧6-認識 . 范式
- 第2章: 普通模式
- 第3章: 插入模式
- 第4章: 可視模式
- 第5章: 命令行模式
- 第6章: 管理多個文件
- 第7章: 打開及保存文件
- 第8章: 用動作命令在文檔中移動
- 第9章: 在文件間跳轉
- 第10章: 復制與粘貼
- 第11章: 宏
- 第12章: 按模式匹配及按原義匹配
- 第13章: 查找
- 第14章: 替換
- 第15章: global命令
- 第16章: 通過ctags建立索引并用其瀏覽源代碼
- 第17章: 編譯代碼并通過Quickfix列表瀏覽錯誤信息
- 第18章: 通過grep,vimgrep以及其他工具對整個工程進行查找
- 第19章: 自動補全
- 第20章: 利用Vim的拼寫檢查器查找并更正拼寫錯誤
- 第21章: 接下來干什么
- 附錄A 根據個人喜好定制Vim
- 終端命令記錄回放工具
- screen使用
- iftop查看網絡流量
- dna螺旋
- shell下的俄羅斯方塊
- 正經英語
- 有意思
- 問題記錄
- python相關
- pip安裝缺少openssl和libssl
- shell相關
- debian下執行數組變量報錯
- 服務相關問題
- ububtu安裝apache2報錯
- php升級mongo拓展插件
- elk節點分片失敗
- 操作系統相關問題
- 運維記錄
- 數據庫相關
- mongo3.4安裝以及優化參數腳本
- mongodb版本升級及優化
- redis動態取消rdb保存配置
- 代理負載均衡相關
- haproxy匹配ua規則分離搜索引擎流量
- haproxy不記錄某個域名或多個域名的日志
- 其他相關
- ImageMagick升級
- NFS強制卸載掛載
- 命令相關
- curl獲取指定域名ip的狀態碼
- awk相關記錄
- rsync傳輸限速指定ssh端口
- 操作系統相關
- centos使用阿里源
- ubuntu更換國內源
- 查看操作系統版本
- 內核優化
- Centos7修改語言為英文
- debian安裝xfs格式化工具
- 查看磁盤信息
- debian的啟動管理工具
- debian安裝vmtools
- debian重啟網卡不生效的解決
- 容器虛擬化
- Docker相關
- dokcer安裝
- docker常用命令
- docker簡單腳本
- Dockerfile相關
- 帶ssh的debian鏡像
- deocker創建簡單鏡像
- 官方文檔
- docker-compose安裝
- 報錯
- docker鏡像加速
- k8s相關
- k8s常用命令
- k8s名詞解釋
- k8s相關的 yaml文件
- VM相關
- 使用VMwareWorkstation批量操作linux虛擬機
- 在windows下使用shell批量操作Vmwarworkstation
- windows下批量操作虛擬機
- ESXI相關
- vsphere網絡相關
- 小愛好
- 不方便展示