【云原生-Docker】快速搭建日常应用部署

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 【云原生-Docker】快速搭建日常应用部署

基础环境准备


基础信息

docker通讯底层基于iptables,firewalld也是对iptables的封装

docker-compose是单击容器编排工具

docker-swarm跨机器进行容器编排,docker内置

kubernetes 用于大量容器编排工具

docker安装

linux docker 安装

docker快速构建应用

mysql

docker run -p 3306:3306 --name mysql -v /home/docker/mysql/conf:/etc/mysql -v /home/docker/mysql/logs:/logs -v /home/docker/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=12ncqOwTCGyg7tYbr34 -d mysql:5.7

映射外网端口:3306

容器名字: mysql

宿主机持久化、日志、配置文件目录:/home/docker

版本: 5.7

默认的root密码: 12ncqOwTCGyg7tYbr34

postgre

docker run -p 5432:5432 -v /home/docker/postgresql/data:/var/lib/postgresql/data -e POSTGRES_PASSWORD=123456 -e TZ=PRC --name=postgres postgres

映射外网端口:5432

容器名字: postgres

宿主机持久化目录:/home/docker/postgresql/data

默认的root密码: 123456

nacos

docker run --env MODE=standalone --name nacos -d -p 8848:8848 nacos/nacos-server

映射外网端口:8848

容器名字: nacos

模式为单机启动:MODE

gogs

docker run -d -p 10022:22 -p 10080:3000 --name=gogs -v /home/gogs/data/:/data gogs/gogs

映射外网端口:10080

容器名字: nacos

模式为单机启动:MODE

sentinel

docker run --name sentinel -d -p 8858:8858 -d bladex/sentinel-dashboard

映射外网端口:8858

容器名字: sentinel

zipkin

docker run -d --restart always -p 9411:9411 --name zipkin openzipkin/zipkin

映射外网端口:9411

容器名字: zipkin

jenkins

docker run -d \
  --restart always \
  --name jenkins \
  -u root \
  -p 5892:8080 \
  -v /home/docker/jenkins/jenkins-data:/var/jenkins_home \
  -v /home/docker/jenkins/docker.sock:/var/run/docker.sock \
  -v /home/docker/jenkins:/home \
  jenkinsci/blueocean

映射外网端口:5892

容器名字: jenkins

宿主机持久化目录:/home/docker/jenkins

nginx

docker run -d -p 8100:80 \
--name nginx \
-v /home/nginx/html:/usr/share/nginx/html \
-v /home/nginx/nginx.conf:/etc/nginx/nginx.conf \
-v /home/nginx/logs:/var/log/nginx \
-v /home/nginx/conf.d/default.conf:/etc/nginx/conf.d/default.conf \
--privileged=true \
nginx

映射外网端口:8100

容器名字: nginx

宿主机持久化目录:/home/nginx

rancher

docker run -d -v /home/docker/rancher/mysql-data/mysql:/var/lib/mysql --restart=unless-stopped -p 5652:8080 rancher/server

映射外网端口:5652

redis

docker run -p 6379:6379 --name redis -v /home/redis/redis.conf:/etc/redis/redis.conf -v /home/redis/data:/data -d redis redis-server /etc/redis/redis.conf --appendonly yes --requirepass 123456

映射外网端口:6379

容器名字: redis

宿主机持久化目录:/home/redis

redis密码:123456

portainer

docker run -d -p 9000:9000 \
--restart=always \
-v /var/run/docker.sock:/var/run/docker.sock \
--name portainer portainer/portainer

映射外网端口:9000

容器名字: portainer

rocketMQ

nameServer
docker run -d \
--name rmqnamesrv \
-p 19876:9876 \
-v /home/docker/rocketmq/data/namesrv/logs:/root/logs \
-v /home/docker/rocketmq/data/namesrv/store:/root/store \
-e "JAVA_OPTS=-Duser.home=/opt" \
-e "JAVA_OPT_EXT=-server -Xms1024m -Xmx1024m" \
rocketmqinc/rocketmq sh mqnamesrv

映射外网端口:19876

容器名字: rmqnamesrv

宿主机持久化目录:/home/docker/rocketmq/data

broker服务器

docker run -d \
--name rmqbroker \
-v /home/docker/rocketmq/data/broker/logs:/root/logs \
-v /home/docker/rocketmq/data/broker/store:/root/store \
-v /home/docker/rocketmq/data/conf/broker.conf:/opt/rocketmq/conf/broker.conf \
--link rmqnamesrv:namesrv -e "NAMESRV_ADDR=IP:19876" \
-e "JAVA_OPTS=-Duser.home=/opt" \
-e "JAVA_OPT_EXT=-server -Xms1024m -Xmx1024m" \
rocketmqinc/rocketmq sh mqbroker -c /home/docker/rocketmq/broker/broker.conf

映射外网端口:10911

容器名字: rmqbroker

宿主机持久化目录:/home/docker/rocketmq/data/broker

NAMESRV_ADDR=IP:19876 当前的rmqnamesrv IP及端口

界面控制台

docker run -d \
-e "JAVA_OPTS=-Drocketmq.config.namesrvAddr=IP:19876 -Drocketmq.config.isVIPChannel=false" \
-p 9993:8080 -t styletang/rocketmq-console-ng

映射外网端口:9993

namesrvAddr=IP:19876 当前的rmqnamesrv IP及端口
rocketMQ docker-compose启动
version: '3.5'
services:
  rmqnamesrv:
    image: rocketmqinc/rocketmq-namesrv
    container_name: rmqnamesrv
    ports:
      - 19876:9876
    volumes:
      - /home/docker/rocketmq/namesrv/logs:/opt/logs
      - /home/docker/rocketmq/namesrv/store:/opt/store
  rmqbroker:
    image: rocketmqinc/rocketmq-broker
    container_name: rmqbroker
    ports:
      - 10909:10909
      - 10911:10911
    volumes:
      - /home/docker/rocketmq/broker/logs:/opt/logs
      - /home/docker/rocketmq/broker/store:/opt/store
      - /home/docker/rocketmq/broker/broker.conf:/etc/rocketmq/broker.conf
    environment:
        NAMESRV_ADDR: "192.168.0.37:19876"
        JAVA_OPTS: " -Duser.home=/opt"
        JAVA_OPT_EXT: "-server -Xms128m -Xmx128m -Xmn128m"
    command: mqbroker -c /home/docker/rocketmq/broker/broker.conf
    depends_on:
      - rmqnamesrv
  rmqconsole:
    image: styletang/rocketmq-console-ng
    container_name: rmqconsole
    ports:
      - 7799:8080
    environment:
        JAVA_OPTS: "-Drocketmq.namesrv.addr=192.168.0.37:19876 -Dcom.rocketmq.sendMessageWithVIPChannel=false"
    depends_on:
      - rmqnamesrv

xxl-job

docker run -d \
    -e PARAMS="--spring.datasource.url=jdbc:mysql://192.168.0.37:3307/xxl_job?Unicode=true&characterEncoding=UTF-8 --spring.datasource.username=root --spring.datasource.password=123456 --xxl.job.accessToken=a984ddf0-ce9d-40a2-84d3-3ffba0d21ee0" \
    -e JAVA_OPTS="-Xms512m -Xmx512m" \
    -p 7777:8080 \
    -v /home/docker/xxllog:/data/applogs \
    --name xxl-job-admin xuxueli/xxl-job-admin:2.3.0

映射外网端口:7777

容器名字: xxl-job-admin

宿主机持久化目录:/home/docker/rocketmq/data/broker

-e PARAMS 配置JDBC信息

netdata

docker run -d --name=netdata \
  -p 19999:19999 \
  -v /home/docker/netdata/netdataconfig:/etc/netdata \
  -v /home/docker/netdata/netdatalib:/var/lib/netdata \
  -v /home/docker/netdata/netdatacache:/var/cache/netdata \
  -v /home/docker/netdata/etc/passwd:/host/etc/passwd:ro \
  -v /home/docker/netdata/etc/group:/host/etc/group:ro \
  -v /home/docker/netdata/proc:/host/proc:ro \
  -v /home/docker/netdata/sys:/host/sys:ro \
  -v /home/docker/netdata/etc/os-release:/host/etc/os-release:ro \
  --restart unless-stopped \
  --cap-add SYS_PTRACE \
  --security-opt apparmor=unconfined \
  netdata/netdata

activemq

docker run --name='activemq' \
      -itd \
      -p 8161:8161 \
      -p 61616:61616 \
      -e ACTIVEMQ_ADMIN_LOGIN=admin \
      -e ACTIVEMQ_ADMIN_PASSWORD=123456 \
      --restart=always \
      -v /usr/soft/activemq:/data/activemq \
      -v /usr/soft/activemq/log:/var/log/activemq \
      webcenter/activemq:latest

扩展知识

kubeadm搭建k8s集群

docker常用命令总结大全

到底什么是云原生?下一个内卷

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
打赏
0
0
0
0
6
分享
相关文章
Docker环境下快速部署RabbitMQ教程。
就这样,你成功地用魔法召唤出了RabbitMQ,还把它和你的应用程序连接了起来。现在,消息会像小溪流水一样,在你的系统中自由流淌。别忘了,兔子们不喜欢孤独,他们需要你细心的关怀,不时地监控它们,确保他们的世界运转得井井有条。
85 18
MAZANOKE:一款隐私优先的浏览器图像优化工具及Docker部署指南
MAZANOKE 是一款简易的图片优化工具,它直接在浏览器中运行,支持离线使用,并确保您的图片始终保留在设备上,绝不外泄。 这款专为普通人设计的工具,适合与亲友分享使用,是那些来路不明的"免费"在线工具的可靠替代品。
40 1
MAZANOKE:一款隐私优先的浏览器图像优化工具及Docker部署指南
【赵渝强老师】数据库不适合Docker容器化部署的原因
本文介绍了在Docker中部署MySQL数据库并实现数据持久化的方法,同时分析了数据库不适合容器化的原因。通过具体步骤演示如何拉取镜像、创建持久化目录及启动容器,确保数据安全存储。然而,由于数据安全性、硬件资源争用、网络带宽限制及额外隔离层等问题,数据库服务并不完全适合Docker容器化部署。文中还提到数据库一旦部署通常无需频繁升级,与Docker易于重构和重新部署的特点不符。
202 18
【赵渝强老师】数据库不适合Docker容器化部署的原因
在Docker容器中部署GitLab服务器的步骤(面向Ubuntu 16.04)
现在,你已经成功地在Docker上部署了GitLab。这就是我们在星际中的壮举,轻松如同土豆一样简单!星际旅行结束,靠岸,打开舱门,迎接全新的代码时代。Prepare to code, astronaut!
93 12
无感改造,完美监控:Docker 多阶段构建 Go 应用无侵入观测
本文将介绍一种基于 Docker 多阶段构建的无侵入 Golang 应用观测方法,通过此方法用户无需对 Golang 应用源代码或者编译指令做任何改造,即可零成本为 Golang 应用注入可观测能力。
237 85
docker arm架构部署kafka要点
本内容介绍了基于 Docker 的容器化解决方案,包含以下部分: 1. **Docker 容器管理**:通过 Portainer 可视化管理工具实现对主节点和代理节点的统一管理。 2. **Kafka 可视化工具**:部署 Kafka-UI 以图形化方式监控和管理 Kafka 集群,支持动态配置功能, 3. **Kafka 安装与配置**:基于 Bitnami Kafka 镜像,提供完整的 Kafka 集群配置示例,涵盖 KRaft 模式、性能调优参数及数据持久化设置,适用于高可用生产环境。 以上方案适合 ARM64 架构,为用户提供了一站式的容器化管理和消息队列解决方案。
131 10
Docker的常见应用部署技巧
以上就是一些Docker的常见应用部署技巧。使用Docker,你可以更容易地部署和管理你的应用,而不需要关心底层的硬件和操作系统。只要你掌握了这些技巧,你就可以更有效地使用Docker来部署你的应用。
104 25
Ubuntu下部署及操作Docker技巧
以上就是在Ubuntu下部署及操作Docker的具体步骤。但这只是冰山一角,Docker的魅力远不仅如此。你可以将其视为存放各种工具的小箱子,随时随地取用,极大地提升工作效率。你也可以私人订制,适应不同的开发环境,就像一个拥有各种口味冰淇淋的冰箱,满足各种各样的需求。好了,现在你已经掌握了基本的Docker运用技巧,快去尝试使用吧!记住,沉浸在探索中,你会找到无尽的乐趣和满满的收获。
203 23
大模型文件Docker镜像化部署技术详解
大模型文件Docker镜像化部署技术详解
494 2
|
4月前
|
在Docker上部署Ollama+AnythingLLM完成本地LLM Agent部署
通过以上步骤,您可以成功在Docker上部署Ollama和AnythingLLM,实现本地LLM Agent的功能。在部署过程中,确保环境和配置正确,以避免不必要的问题。希望本文能够帮助您顺利完成部署,并在本地环境中高效地使用LLM模型。
1403 8
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问