其他分享
首页 > 其他分享> > Docker 部署Mycat2

Docker 部署Mycat2

作者:互联网

简介

Mycat是一个彻底开源的,面向企业应用开发的大数据库集群。从定义和分类来看,它是一个开源的分布式数据库系统,是一个实现了MySQL协议的服务器,前端用户可以把它看作是一个数据库代理,用MySQL客户端工具和命令行访问,而其后端可以用MySQL原生协议与多个MySQL服务器通信,也可以用JDBC协议与大多数主流数据库服务器通信,其核心功能是分表分库,即将一个大表水平分割为N个小表,存储在后端MySQL服务器里或者其他数据库里。

http://www.mycat.org.cn/

创建镜像

1. 安装资源地址

http://dl.mycat.org.cn/2.0/

2. Dockerfile文件

FROM openjdk:8-jre

ENV AUTO_RUN_DIR ./mycat2
ENV DEPENDENCE_FILE mycat2-1.22-release-jar-with-dependencies.jar
ENV TEMPLATE_FILE mycat2-install-template-1.21.zip

RUN sed -i "s@http://.*archive.ubuntu.com@http://mirrors.aliyun.com@g" /etc/apt/sources.list
RUN sed -i "s@http://.*security.ubuntu.com@http://mirrors.aliyun.com@g" /etc/apt/sources.list

RUN buildDeps='procps wget unzip' \
&& apt-get update \
&& apt-get install -y $buildDeps

# 安装地址 http://dl.mycat.org.cn/2.0/
# http://dl.mycat.org.cn/2.0/1.22-release/
# http://dl.mycat.org.cn/2.0/install-template/
RUN wget -P $AUTO_RUN_DIR/ http://dl.mycat.org.cn/2.0/1.22-release/$DEPENDENCE_FILE \
&& wget -P $AUTO_RUN_DIR/ http://dl.mycat.org.cn/2.0/install-template/$TEMPLATE_FILE

RUN cd $AUTO_RUN_DIR/ \
&& unzip $TEMPLATE_FILE \
&& ls -al . \
&& mv $DEPENDENCE_FILE mycat/lib/ \
&& chmod +x mycat/bin/* \
&& chmod 755 mycat/lib/* \
&& mv mycat /usr/local

#copy mycat /usr/local/mycat/
VOLUME /usr/local/mycat/conf
VOLUME /usr/local/mycat/logs

EXPOSE 8066 1984
CMD ["/usr/local/mycat/bin/mycat", "console"]

3. 编译镜像

docker build -t mycat2:1.22 .

创建容器

1. 复制配置

docker run -d --name=mycat2 -p 8066:8066 -p 1984:1984 mycat2:1.22

# 复制容器内配置
docker cp mycat2:/usr/local/mycat/conf .
docker cp mycat2:/usr/local/mycat/logs .

2. 创建容器

docker run -d --name=mycat2 -p 8066:8066 -p 1984:1984 -v $PWD/conf:/usr/local/mycat/conf -v $PWD/logs:/usr/local/mycat/logs mycat2:1.22

# 以root用户权限进入容器
docker exec -it -u root mycat2 bash
# 查看容器启动日志
docker logs -f mycat2

3. docker-compose方式安装

version: '3'
services:
  mycat-service:
    build:
      context: ./mycat/
      dockerfile: Dockerfile
    image: mycat2:1.22
    container_name: mycat2
    restart: always
    network_mode: "host"
    volumes:
      - /u01/mycat2/conf:/usr/local/mycat/conf
      - /u01/mycat2/logs:/usr/local/mycat/logs

标签:http,部署,mycat2,mycat,usr,&&,Docker,local,Mycat2
来源: https://www.cnblogs.com/wufengsheng/p/16320253.html