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

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: 【云原生-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常用命令总结大全

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

相关文章
|
3月前
|
消息中间件 人工智能 安全
云原生进化论:加速构建 AI 应用
本文将和大家分享过去一年在支持企业构建 AI 应用过程的一些实践和思考。
842 45
|
3月前
|
应用服务中间件 网络安全 nginx
手把手教你使用 Docker 部署 Nginx 教程
本文详解Nginx核心功能与Docker部署优势,涵盖镜像拉取、容器化部署(快速、挂载、Compose)、HTTPS配置及常见问题处理,助力高效搭建稳定Web服务。
1464 4
|
3月前
|
应用服务中间件 Linux nginx
在虚拟机Docker环境下部署Nginx的步骤。
以上就是在Docker环境下部署Nginx的步骤。需要注意,Docker和Nginix都有很多高级用法和细节需要掌握,以上只是一个基础入门级别的教程。如果你想要更深入地学习和使用它们,请参考官方文档或者其他专业书籍。
186 5
|
3月前
|
监控 Kubernetes 安全
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
蒋星熠Jaxonic,技术探索者,以代码为笔,在二进制星河中书写极客诗篇。专注Docker与容器化实践,分享从入门到企业级应用的深度经验,助力开发者乘风破浪,驶向云原生新世界。
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
|
4月前
|
存储 Docker Python
docker 部署 sftp
本文介绍SFTP服务的部署与配置,包括users.conf用户配置规则、Docker容器运行命令及上传目录权限说明,重点解析atmoz/sftp镜像的chroot机制与子目录映射,确保用户登录后正确访问/upload目录,并提供Python脚本实现文件上传示例。
398 12
docker 部署 sftp
|
4月前
|
运维 Linux 数据库
基于 Docker 部署 n8n 指南,新手一看就会
本教程详解如何通过 Docker 快速部署开源自动化工具 n8n,适合新手快速上手。内容涵盖官方部署步骤、常见难点及第三方一键部署方案,助你高效搭建自动化工作流平台。
1698 6
|
3月前
|
存储 NoSQL Redis
手把手教你用 Docker 部署 Redis
Redis是高性能内存数据库,支持多种数据结构,适用于缓存、消息队列等场景。本文介绍如何通过Docker快速拉取轩辕镜像并部署Redis,涵盖快速启动、持久化存储及docker-compose配置,助力开发者高效搭建稳定服务。
1088 7
|
3月前
|
存储 搜索推荐 数据库
🚀 RAGFlow Docker 部署全流程教程
RAGFlow是开源的下一代RAG系统,融合向量数据库与大模型,支持全文检索、插件化引擎切换,适用于企业知识库、智能客服等场景。支持Docker一键部署,提供轻量与完整版本,助力高效搭建私有化AI问答平台。
2602 8
|
3月前
|
Java Linux 虚拟化
【Docker】(1)Docker的概述与架构,手把手带你安装Docker,云原生路上不可缺少的一门技术!
1. Docker简介 1.1 Docker是什么 为什么docker会出现? 假定您在开发一款平台项目,您的开发环境具有特定的配置。其他开发人员身处的环境配置也各有不同。 您正在开发的应用依赖于您当前的配置且还要依赖于某些配置文件。 您的企业还拥有标准化的测试和生产环境,且具有自身的配置和一系列支持文件。 **要求:**希望尽可能多在本地模拟这些环境而不产生重新创建服务器环境的开销 问题: 要如何确保应用能够在这些环境中运行和通过质量检测? 在部署过程中不出现令人头疼的版本、配置问题 无需重新编写代码和进行故障修复
413 2