文档章节

nacos standalone with MySQL On K8S

ArcticF0X
 ArcticF0X
发布于 2019/11/06 16:51
字数 698
阅读 48
收藏 0

nacos 部署在k8s 上的例子是使用的stateful 三节点加 MySQL 主从,对于测试环境来说太占资源了。官方给出的 docker-compose 单节点也是 MySQL 主从,对于测试环境没必要。所以在测试环境上基于官方的例子作出一些修改,部署一个单节点的 nacos-server 和 单节点MySQL,记录一些使用的文件。 Dockerfile:

FROM openjdk

ENV TIME_ZONE=Asia/Shanghai \
    MODE="standalone" \
    PREFER_HOST_MODE="ip"\
    BASE_DIR="/home/nacos" \
    CLASSPATH=".:/home/nacos/conf:$CLASSPATH" \
    CLUSTER_CONF="/home/nacos/conf/cluster.conf" \
    FUNCTION_MODE="all" \
    NACOS_USER="nacos" \
    JVM_XMS="2g" \
    JVM_XMX="2g" \
    JVM_XMN="1g" \
    JVM_MS="128m" \
    JVM_MMS="320m" \
    NACOS_DEBUG="n" \
    TOMCAT_ACCESSLOG_ENABLED="false" \
    JAVA="/usr/java/openjdk-13/bin/java"

WORKDIR /$BASE_DIR

RUN set -x && \
    yum update -y && \
    yum install iputils nc libcurl -y  && \
    ln -snf /usr/share/zoneinfo/$TIME_ZONE /etc/localtime && echo '$TIME_ZONE' > /etc/timezone && \
    yum autoremove && yum clean all

COPY ./nacos /home/nacos
# set startup log dir
RUN mkdir -p logs \
	&& cd logs \
	&& touch start.out \
	&& ln -sf /dev/stdout start.out \
	&& ln -sf /dev/stderr start.out

EXPOSE 8848
ENTRYPOINT ["bin/docker-startup.sh"]

application.properties

# spring
server.servlet.contextPath=${SERVER_SERVLET_CONTEXTPATH:/nacos}
server.contextPath=/nacos
server.port=${NACOS_SERVER_PORT:8848}
spring.datasource.platform=${SPRING_DATASOURCE_PLATFORM:""}
nacos.cmdb.dumpTaskInterval=3600
nacos.cmdb.eventTaskInterval=10
nacos.cmdb.labelTaskInterval=300
nacos.cmdb.loadDataAtStart=false
db.num=${MYSQL_DATABASE_NUM:2}
db.url.0=jdbc:mysql://${MYSQL_MASTER_SERVICE_HOST}:${MYSQL_MASTER_SERVICE_PORT:3306}/${MYSQL_MASTER_SERVICE_DB_NAME}?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=${MYSQL_MASTER_SERVICE_USER}
db.password=${MYSQL_MASTER_SERVICE_PASSWORD}
server.tomcat.accesslog.enabled=${TOMCAT_ACCESSLOG_ENABLED:false}
server.tomcat.accesslog.pattern=%h %l %u %t "%r" %s %b %D
# default current work dir
server.tomcat.basedir=
## spring security config
### turn off security

nacos.security.ignore.urls=/,/**/*.css,/**/*.js,/**/*.html,/**/*.map,/**/*.svg,/**/*.png,/**/*.ico,/console-fe/public/**,/v1/auth/login,/v1/console/health/**,/v1/cs/**,/v1/ns/**,/v1/cmdb/**,/actuator/**,/v1/console/server/**
# metrics for elastic search
management.metrics.export.elastic.enabled=false
management.metrics.export.influx.enabled=false

nacos.naming.distro.taskDispatchThreadCount=10
nacos.naming.distro.taskDispatchPeriod=200
nacos.naming.distro.batchSyncKeyCount=1000
nacos.naming.distro.initDataRatio=0.9
nacos.naming.distro.syncRetryDelay=5000
nacos.naming.data.warmup=true

MySQL PVC

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: nacos-mysql-pvc
spec:
  accessModes:
    - ReadWriteOnce
  storageClassName: rook-ceph-block
  resources:
    requests:
      storage: 5Gi

MySQL Deployment

apiVersion: apps/v1
kind: Deployment
metadata:
  name: nacos-mysql
spec:
  selector:
    matchLabels:
      app: nacos-mysql
  template:
    metadata:
      labels:
        app: nacos-mysql
    spec:
      containers:
      - name: nacos-mysql
        image: nacos/nacos-mysql-master:latest
        resources:
          limits:
            memory: "1024Mi"
            cpu: "1000m"
          requests:
            memory: "512Mi"
        ports:
        - containerPort: 3306
        env:
        - name: MYSQL_ROOT_PASSWORD
          value: "root"
        - name: MYSQL_USER
          value: "nacos"
        - name: MYSQL_PASSWORD
          value: "nacos"
        - name: MYSQL_REPLICATION_USER
          value: 'nacos_ru'
        - name: MYSQL_REPLICATION_PASSWORD
          value: 'nacos_ru'
        volumeMounts:
        - name: mysql-persistent-storage
          mountPath: /var/lib/mysql
          subPath: mysql
          readOnly: false
      volumes:
      - name: mysql-persistent-storage
        persistentVolumeClaim:
          claimName: nacos-mysql-pvc
---
apiVersion: v1
kind: Service
metadata:
  name: nacos-mysql
  labels:
    name: nacos-mysql
spec:
  selector:
    app: nacos-mysql
  ports:
  - name mysql-remote
     port: 3306

nacos PVC

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: nacos-server-plugindir
spec:
  accessModes:
    - ReadWriteOnce
  storageClassName: rook-ceph-block
  resources:
    requests:
      storage: 5Gi
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: nacos-server-datadir
spec:
  accessModes:
    - ReadWriteOnce
  storageClassName: rook-ceph-block
  resources:
    requests:
      storage: 5Gi

nacos deployment

apiVersion: apps/v1
kind: Deployment
metadata:
  name: nacos-server
spec:
  selector:
    matchLabels:
      app: nacos-server
  template:
    metadata:
      labels:
        app: nacos-server
    spec:
      containers:
      - name: nacos-server
        image: registry.cn-hangzhou.aliyuncs.com/private/nacos-server:standalone-1.0
        resources:
          limits:
            memory: "640Mi"
            cpu: "500m"
          requests:
            memory: "256Mi"
        ports:
        - containerPort: 8848
        env:
          - name: MYSQL_MASTER_SERVICE_DB_NAME
            value: "nacos_devtest"
          - name: MYSQL_MASTER_SERVICE_PORT
            value: "3306"
          - name: MYSQL_MASTER_SERVICE_USER
            value: "nacos"
          - name: MYSQL_MASTER_SERVICE_PASSWORD
            value: "nacos"
          - name: MYSQL_MASTER_SERVICE_HOST
            value: "nacos-mysql"
          - name: NACOS_SERVER_PORT
            value: "8848"
          - name: PREFER_HOST_MODE
            value: "hostname"
        readinessProbe:
          httpGet:
            port: 8848
            path: /nacos/v1/console/health/readiness
          initialDelaySeconds: 60
          timeoutSeconds: 3
        livenessProbe:
          httpGet:
            port: 8848
            path: /nacos/v1/console/health/liveness
          initialDelaySeconds: 60
          timeoutSeconds: 3
        volumeMounts:
          - name: plugindir
            mountPath: /home/nacos/plugins/peer-finder
          - name: datadir
            mountPath: /home/nacos/data
      volumes:
      - name: plugindir
        persistentVolumeClaim:
          claimName: nacos-server-plugindir
      - name: datadir
        persistentVolumeClaim:
          claimName: nacos-server-datadir
---
apiVersion: v1
kind: Service
metadata:
  name: nacos-server
  labels:
    name: nacos-server
spec:
  selector:
    app: nacos-server
  ports:
  - name: nacos-client
    port: 8848

© 著作权归作者所有

ArcticF0X

ArcticF0X

粉丝 6
博文 11
码字总数 2877
作品 0
长沙
私信 提问
加载中

评论(0)

微服务配置中心 Nacos Docker 部署

> 部署 Nacos 1、部署 MySQL 5.7 集群 master & slave Docker 部署方式请参考:使用 Docker 部署 MySQL 5.7 & 8.0 主从集群 2、创建数据库 nacos 3、在 mysql-master 上执行 SQL SQL 文件:h...

Anoyi
2019/03/20
0
0
nacos集群部署-k8s环境

通过StatefulSets 在Kubernetes上部署Nacos 快速部署可以参考官网https://nacos.io/en-us/docs/use-nacos-with-kubernetes.html 1 快速部署 git clone https://github.com/nacos-group/nacos......

super李导
2019/10/25
0
0
一:nacos 的安装与启动方式

一: nacos 的下载与安装 1,下载 到 github下载 nacos-server-1.2.0.zip 文件 :https://github.com/alibaba/nacos/releases 解压后的目录结构如图: 2,安装 在0.7版本之前,在单机模式时n...

Sam Xiao
03/26
0
0
Nacos部署中的一些常见问题汇总

开个帖子,汇总一下读者经常提到的一些问题 问题一:Ubuntu下启动Nacos报错 问题描述 使用命令启动报错: 解决方法 改用命令启动 问题二:Failed to create database '/data/soft/nacos/dat...

程序猿DD
2019/05/10
97
0
Nacos v0.7.0:对接CMDB,实现基于标签的服务发现能力

Nacos近期发布了0.7.0版本,该版本支持对接第三方CMDB获取CMDB数据、使用Selector机制来配置服务的路由类型、支持单机模式使用MySQL数据库、上线Node.js客户端,并修复了一些bug。 -> “阿里...

中间件小哥
2018/12/21
0
0

没有更多内容

加载失败,请刷新页面

加载更多

北京哪里有开电子餐饮费发票

开电子餐饮费发票发票电薇13564998196从主业来看,2019年众诚保险围绕车险业务采取增设分支机构、加强合作、优化用户体验等动作,但综合成本率仍有所上行,业内指出,车险的价格透明度属天然...

枅票嶶fp2090
25分钟前
32
0
哪里有开电子餐饮费发票

开电子餐饮费发票发票电薇13564998196从主业来看,2019年众诚保险围绕车险业务采取增设分支机构、加强合作、优化用户体验等动作,但综合成本率仍有所上行,业内指出,车险的价格透明度属天然...

枅票微fp2090
30分钟前
37
0
略谈分布式系统中的容器设计模式

本文作者:zytan_cocoa 略谈分布式系统中的容器设计模式 谭中意 2020/3/5 前言:云原生(Cloud Native)不仅仅是趋势,更是现在进行时,它是构建现代的,可弹性伸缩的,快速迭代的计算网络服...

百度开发者中心
03/11
17
0
OSChina 周三乱弹 —— 小姐姐的领带有点带歪了,请帮忙正一下

Osc乱弹歌单(2020)请戳(这里) 【今日歌曲】 @薛定谔的兄弟 :分享洛神有语创建的歌单「我喜欢的音乐」: 《アイタクテ -voice & piano-》- 和紗 手机党少年们想听歌,请使劲儿戳(这里) ...

小小编辑
今天
23
0
对象名称前的单下划线和双下划线是什么意思?

问题: Can someone please explain the exact meaning of having leading underscores before an object's name in Python? 有人可以解释一下在Python中对象名称前加下划线的确切含义吗? ......

技术盛宴
今天
29
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部