kubernetes上安装MongoDB-3.6.5集群副本集方式
一、安装部署:
想直接一步创建集群的小伙伴直接按以下步骤安装(再往后是记录自己出过的错):
1、生成docker镜像:
docker build -t 144.202.127.156/library/mongodb:3.4.10 .
docker push 144.202.127.156/library/mongodb:3.4.10 注:记得把地址换成自己的镜像仓库
FROM alpine:edge
MAINTAINER chengcuichao RUN apk update && \
echo http://dl-4.alpinelinux.org/alpine/edge/testing >> /etc/apk/repositories && \
apk add --no-cache mongodb numactl numactl-tools
Dockerfile
2、在kubernete上创建:
kubectl create -f mongodb.yml
在此注意几下几点:
1)、将为外置存储的Secret和storageclass换成自己的。 注:我用的是ceph,其他的根据自己的更改,也可以不用持久化存储,就当测试用。
2)、镜像换成自己的镜像地址。
3)、启动参数--replSet换成自己的,不换也可以。
apiVersion: v1
kind: Namespace
metadata:
name: basic-app
---
apiVersion: v1
kind: Secret
metadata:
namespace: basic-app
name: ceph-secret
type: "kubernetes.io/rbd"
data:
key: QVFEYmVRTmJZQ1B4TFJBQUg0QS9Tb01NZjF6NHB3L0p1Y3ZUQnc9PQ==
---
apiVersion: v1
kind: Secret
metadata:
namespace: basic-app
name: mongo-key
type: Opaque
data:
key: UERVU0hWVU9KT1ZQVUVYT0JXWU8=
---
apiVersion: v1
kind: ConfigMap
metadata:
name: mongodb-config
namespace: basic-app
data:
mongodb: |
systemLog:
destination: file
path: "/var/log/mongodb/mongodb.log"
logAppend: true
processManagement:
fork: false
net:
port: 27017
bindIp: 0.0.0.0
security:
keyFile: "/etc/conf.d/secret-key/key"
authorization: enabled
storage:
dbPath: /var/lib/mongodb
setParameter:
enableLocalhostAuthBypass: true
authenticationMechanisms: SCRAM-SHA-1
mongos: |
MONGOS_EXEC="/usr/bin/mongos"
MONGOS_RUN="/var/run/mongodb"
MONGOS_USER="mongodb"
MONGOS_IP="127.0.0.1"
MONGOS_PORT=""
MONGOS_CONFIGDB=""
MONGOS_OPTIONS=""
---
apiVersion: v1
kind: Service
metadata:
name: mongodb
namespace: basic-app
labels:
name: mongo
spec:
clusterIP: None
ports:
- port: 27017
targetPort: 27017
selector:
app: mongo-cluster
---
apiVersion: apps/v1beta1
kind: StatefulSet
metadata:
name: mongodb
namespace: basic-app
spec:
serviceName: mongodb
replicas: 3
template:
metadata:
labels:
app: mongo-cluster
spec:
terminationGracePeriodSeconds: 10
containers:
- name: mongod
image: 144.202.127.156/library/mongodb:3.6.5
command: ["sh", "-c", "chmod 600 -R /etc/conf.d/secret-key;numactl --interleave=all mongod -f /etc/conf.d/mongodb --auth --replSet icsoc"]
resources:
limits:
cpu: 2
memory: 2G
requests:
cpu: 1
memory: 1G
volumeMounts:
- name: mongodb-data
mountPath: /var/lib/mongodb
- name: mongo-config
mountPath: /etc/conf.d
- name: timezone-config
mountPath: /etc/localtime
- name: secret-key
mountPath: /etc/conf.d/
ports:
- containerPort: 27017
livenessProbe:
tcpSocket:
port: 27017
initialDelaySeconds: 15
periodSeconds: 20
volumes:
- name: mongo-config
configMap:
name: mongodb-config
- name: timezone-config
hostPath:
path: /usr/share/zoneinfo/Asia/Shanghai
- name: secret-key
secret:
secretName: mongo-key
volumeClaimTemplates:
- metadata:
name: mongodb-data
annotations:
volume.beta.kubernetes.io/storage-class: "ceph-db"
spec:
accessModes: [ "ReadWriteOnce" ]
resources:
requests:
storage: 50Gi
mongodb.yml
3、初始化集群:
1、连进容器内:
kubectl exec -it mongodb-0 /bin/sh 2、执行初始化副本集:
mongo
rs.initiate({_id: "icsoc", version: 1, members: [
{ _id: 0, host : "mongodb-0.mongodb.basic-app.svc.cluster.local:27017" },
{ _id: 1, host : "mongodb-1.mongodb.basic-app.svc.cluster.local:27017" },
{ _id: 2, host : "mongodb-2.mongodb.basic-app.svc.cluster.local:27017" }
]}); 2、创建管理用户: 具体可参考:https://docs.mongodb.com/manual/tutorial/enable-authentication/
use admin
db.createUser(
{
user: "myUserAdmin",
pwd: "P@ssw0rd",
roles: [ { role: "userAdminAnyDatabase", db: "admin" } ]
}
)
db.auth("myUserAdmin","P@ssw0rd") 3、之后就可以连进去创建用户,赋予角色权限使用。
二、以下记录创建详细步骤:
1、在kubenetes安装mongodb集群大体思路为:
1)、先在一个基础的镜像里安装mongodb,启动正常后无报错。
2)、再理清楚mogodb副本集集群是怎么启动的。
3)、之后编写在kubernetes创建资源的文件。
4)、先创建看看那进行不下去,再一个个解决。
2、在alpine:edge基础上编写dockerfile:
编写好的Dockerfile如下:
FROM alpine:edge
MAINTAINER chengcuichao RUN apk update && \
echo http://dl-4.alpinelinux.org/alpine/edge/testing >> /etc/apk/repositories && \
apk add --no-cache mongodb numactl COPY run.sh /root/
RUN chmod +x /root/run.sh CMD /root/run.sh
Dockerfile
先在docker上启动,mongo连进去后报错:
Server has startup warnings:
2018-07-15T12:25:52.064+0800 W CONTROL [main] --diaglog is deprecated and will be removed in a future release
2018-07-15T12:25:52.183+0800 I STORAGE [initandlisten]
2018-07-15T12:25:52.183+0800 I STORAGE [initandlisten] ** WARNING: Using the XFS filesystem is strongly recommended with the WiredTiger storage engine
2018-07-15T12:25:52.183+0800 I STORAGE [initandlisten] ** See http://dochub.mongodb.org/core/prodnotes-filesystem 第一个报错
2018-07-15T12:26:02.364+0800 I CONTROL [initandlisten] ** WARNING: You are running this process as the root user, which is not recommended. 第二个
2018-07-15T12:26:02.364+0800 I CONTROL [initandlisten]
2018-07-15T12:26:02.364+0800 I CONTROL [initandlisten]
2018-07-15T12:26:02.364+0800 I CONTROL [initandlisten] ** WARNING: You are running on a NUMA machine.
2018-07-15T12:26:02.364+0800 I CONTROL [initandlisten] ** We suggest launching mongod like this to avoid performance problems:
2018-07-15T12:26:02.364+0800 I CONTROL [initandlisten] ** numactl --interleave=all mongod [other options] 第三个
2018-07-15T12:26:02.365+0800 I CONTROL [initandlisten]
2018-07-15T12:26:02.365+0800 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'.
2018-07-15T12:26:02.365+0800 I CONTROL [initandlisten] ** We suggest setting it to 'never' 第四个
2018-07-15T12:26:02.365+0800 I CONTROL [initandlisten]
2018-07-15T12:26:02.365+0800 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'.
2018-07-15T12:26:02.365+0800 I CONTROL [initandlisten] ** We suggest setting it to 'never' 第五个
1)、第一个报错是文件系统的问题,还没解决 。
2)、第二个报错是要开启认证,在启动参数上加入--auth就可以。
3)、第三个报错需要在mongod命令前面加上numactl --interleave=all,在docker容器里执行numactl --interleave=all mongod -f /etc/conf.d/mongodb 在直接用docker起的容器里执行会报错:
set_mempolicy: Operation not permitted
setting interleave mask: Operation not permitted
但在statefulset的yml文件加上command: ["sh", "-c", "numactl --interleave=all mongod -f /etc/conf.d/mongodb --bind_ip 0.0.0.0"],kubectl create -f mongodb.yml创建后不会报错。
4)、第四个和第五个报错需要执行:echo never > /sys/kernel/mm/transparent_hugepage/enabled,echo never > /sys/kernel/mm/transparent_hugepage/defrag,
但是在容器里执行会报错,就算用initContainers
来为mongodb的容器创建运行环境,但是还会报:
/bin/sh: can't create /sys/kernel/mm/transparent_hugepage/enabled: Read-only file system
/bin/sh: can't create /sys/kernel/mm/transparent_hugepage/defrag: Read-only file system
为容器增加守护脚本,以daemonset方式运行: 参考:http://pauldone.blogspot.com/2017/06/mongodb-kubernetes-production-settings.html https://github.com/kubernetes/contrib/tree/master/startup-script
kind: DaemonSet
apiVersion: extensions/v1beta1
metadata:
namespace: basic-app
name: hostvm-configurer
labels:
app: startup-script
spec:
template:
metadata:
labels:
app: startup-script
spec:
hostPID: true
containers:
- name: hostvm-configurer-container
# image: gcr.io/google-containers/startup-script:v1
image: 144.202.127.156/google_containers/startup-script:v1
securityContext:
privileged: true
env:
- name: STARTUP_SCRIPT
value: |
#! /bin/bash
set -o errexit
set -o pipefail
set -o nounset # Disable hugepages
echo 'never' > /sys/kernel/mm/transparent_hugepage/enabled
echo 'never' > /sys/kernel/mm/transparent_hugepage/defrag
config-daemonset
官方文档:https://docs.mongodb.com/manual/replication/
专门在k8s上安装Mongodb:http://k8smongodb.net/
kubernetes上安装MongoDB-3.6.5集群副本集方式的更多相关文章
- Mongodb分布式集群副本集+分片
目录 简介 1. 副本集 1.1 MongoDB选举的原理 1.2 复制过程 2. 分片技术 2.1 角色 2.2 分片的片键 2.3 片键分类 环境介绍 1.获取软件包 2.创建路由.配置.分片等的 ...
- 搭建高可用mongodb集群—— 副本集
转自:http://www.lanceyan.com/tech/mongodb/mongodb_repset1.html 在上一篇文章<搭建高可用MongoDB集群(一)——配置MongoDB& ...
- window配置mongodb集群(副本集)
参数解释: dbpath:数据存放目录 logpath:日志存放路径 pidfilepath:进程文件,有利于关闭服务 logappend:以追加的方式记录日志(boolean值) replSet:副 ...
- MongoDB 高可用集群副本集+分片搭建
MongoDB 高可用集群搭建 一.架构概况 192.168.150.129192.168.150.130192.168.150.131 参考文档:https://www.cnblogs.com/va ...
- MongoDB 3.4 分片集群副本集 认证
连接到router所在的MongoDB Shell 我本机端口设置在50000上 mongo --port 接下来的流程和普通数据库添加用户权限一样 db.createUser({user:&quo ...
- MongoDB集群——副本集
1. 副本集的结构及原理 副本集包括三种节点:主节点.从节点.仲裁节点.主节点负责处理客户端请求,读.写数据, 记录在其上所有操作的oplog: 从节点定期轮询主节点获取这些操作,然后对自己的数据副本 ...
- Ubuntu上安装MongoDB(译)
add by zhj:直接从第四步开始就可以了,而且安装好MongoDB后会自动启动的,不必自己去执行启动命令 原文:https://docs.mongodb.com/manual/tutorial/ ...
- Linux上安装MongoDB
使用本教程使用.rpm 软件包在红帽企业Linux或CentOS Linux版本6和7上安装MongoDB Community Edition . 平台支持 本安装指南仅支持64位系统.详细信息请参见 ...
- Kubernetes上安装Metrics-Server
操作场景 metrics-server 可实现 Kubernetes 的 Resource Metrics API(metrics.k8s.io),通过此 API 可以查询 Pod 与 Node 的部 ...
随机推荐
- USACO4.2.1 网络流最大流算法
/* ID:hk945801 TASK:ditch LANG:C++ */ #include<iostream> #include<cstdio> #include<cs ...
- ChemDraw中化学信息怎么通过Excel搜索
用户可以通过ChemDraw for Excel插件功能在Office Excel中建立ChemOffice菜单将ChemOffice和Excel结合使用,使用电子表格的最大优势之一就是可以清晰查看并 ...
- VC++ ListCtrl Report使用
1.在VC++ 6.0中新建基于对话框的MFC应用程序ListCtrl; 2.在主对话框上添加一个List Control至合适的位置及大小: 3.在对话框OnInitDialog中初始化ListCt ...
- flask模块
import flask, json #把当前的文件当成一个服务 server = flask.Flask(__name__) @server.route('/index', methods=['ge ...
- System.getProperty()方法大全 (转载)
System.out.println("java版本号:" + System.getProperty("java.version")); // java版本号S ...
- 简单的纯css重置input单选多选按钮的样式--利用伪类
由于input单选多选的原生样式通常都不符合需求,所以在实现功能时通常都需要美化按钮 html <input type="radio" /> <input typ ...
- 小程序用scroll-view的scroll-to-view属性实现锚链接跳转
小程序没有锚链接,通过scroll-view可以实现类似锚链接的功能,点击锚链接,滚动条滚动到相应的位置 wxml <view class="wrap"> <!- ...
- 适配器模式(Adpater)
一.适配器模式介绍 适配器模式:将一个类的接口转换成客户希望的另外一个接口.Adapter模式使得原本由于接口不兼容而不能一起工作的类可以一起工作. 例如: NBA中的球员来自不同国家,而世界标准语言 ...
- Orchard 与 ABP架构比较 (aspnetboilerplate)
前言: ABP框架经常在一些.NET群中听群友提起,以前也浏览过官网,大致了解它是一个框架,直到今天本人才正式下载源码入门 ... 经过两个小时的ABP中文文档入门(感谢各位辛勤的翻译者) ,大致了 ...
- nodejs(一)
nodejs第一章节 使用node来实现第一个http服务器 var http = require(‘http’); http.createServer(function (request, resp ...