首页 > 其他分享 >Docker简易部署

Docker简易部署

时间:2023-08-01 23:00:35浏览次数:31  
标签:容器 部署 redis 简易 mysql 镜像 Docker root docker

Docker简易部署

应用部署

mysql部署

# 在宿主机上不需要安装mysql了,直接拉取mysql镜像,运行成容器即可
# 部署步骤
	-1 创建文件夹
    mkdir /root/mysql
	mkdir /root/mysql/conf.d
	mkdir /root/mysql/data/
    
    -2 基于镜像运行成容器(端口映射,目录映射)
    docker run -id --name=mysql3 -p 3306:3306 -v /root/mysql/conf.d:/etc/mysql/conf.d -v /root/mysql/data/:/var/lib/mysql -v /root/mysql/my.cnf:/etc/mysql/my.cnf -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7 
    # 运行mysql 需要传入环境变量
    MYSQL_ROOT_PASSWORD #root超级管理员的密码
    
    -3 mysql配置文件,新建
    	-在mysql文件夹下
        touch my.cnf

    -4 运行2 的命令
    
    -5 远程链接mysql ,创建库,创建表
    -6 在容器中链接mysql,可以看到库和表
    -7 删除容器 
    -8 创建一个新容器,数据还在[一定要做目录映射]
[mysqld]
user=mysql
character-set-server=utf8
default_authentication_plugin=mysql_native_password
secure_file_priv=/var/lib/mysql
expire_logs_days=7
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
max_connections=1000
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8

redis部署

# 步骤:
	-1 拉取redis镜像
    -2 创建文件夹和文件
    	mkdir reids
        mkdir reids/conf
        mkdir reids/data
        vim ./reids/conf/redis.conf
    -3 配置文件
        bind 0.0.0.0
        daemonize NO
        protected-mode no
        requirepass 123456

    -2 docker命令
    # low一些,没有做目录映射
    docker run -di --name=myredis -p 6379:6379 redis
    # 咱们用这个
    docker run -id -p 6379:6379 --name redis_6379 -v /root/reids/conf/redis.conf:/etc/redis/redis.conf -v /root/reids/data:/data redis  redis-server /etc/redis/redis.conf --appendonly yes

部署nginx

# 步骤
	-1 拉取nginx镜像
    -2 docker 命令
    docker run -id --name=nginx -p 80:80 nginx
    -3 从win机器浏览器可以访问:10.0.0.205:80
    -4 今日容器内部,修改index    /usr/share/nginx/html
    -5 修改index.html   
    	-vi  vim都没有,安装发现yum也没有,它不是centos 
        -apt-get update
        -apt-get install vim
        
    -6 访问,发现页面变了
    

迁移与备份

容器做成镜像

# 把容器,打包成镜像--->容器中装了很多软件
	-python 镜像,基于debain做的
    -基于centos ,装python3.8解释器----》镜像---》放到网上给别人用

# 咱们案例,基于ngixn+vim+index改了的 做成镜像
	-docker commit 427066d078c3 nginx_vim

# 基于自己做的镜像,运行成容器
	docker run -id --name=xxx -p 8080:80 nginx_vim:latest

把镜像备份成压缩包

# 把镜像做成tar文件
	docker save -o mynginx.tar nginx_vim
    
# 把压缩包load成镜像
	docker load -i mynginx.tar

Dockerfile(非常重要)

Dockerfile是由一系列命令和参数构成的脚本,这些命令应用于基础镜像并最终创建一个新的镜像,文件名必须叫Dockerfile

# 镜像哪里来?
	-1 远程仓库下载的
    -2 容器做的
    -3 xx.tar 解压出来的
    -4 通过dockerfile构建
    	普通文件,文件中写了很多命令,根据这些命令创建出镜像来
        
        
# 常用命令
	#1  FROM image_name:tag	 基于哪个基础镜像来构建
    #2  MAINTAINER lqz	     声明镜像的创建者
    #3  ENV key value	     设置环境变量 (可以写多条)
    	ENV DB_PASSWORD lqz123  运行容器 -e参数指定 -e DB_PASSWORD=xxxx
    #4  RUN command	           是Dockerfile的核心部分(可以写多条),
    	command  linux命令
   
	# 5 ADD 宿主机路径文件  容器路径文件	  将宿主机的文件复制到容器内,如果是一个压缩文件,将会在复制后自动解压
    # 6 COPY 宿主机路径文件  容器路径文件  将宿主机的文件复制到容器内
    # 7 WORKDIR path_dir	设置工作目录    docker exec 进入到容器,在某个路径下
    # 8 CMD   命令          运行容器默认执行的命令,它可以被替换 
    	CMD:添加启动容器时需要执行的命令。多条只有最后一条生效。可以在启动容器时被覆盖和修改
        
        
        
        
 

简单案例基于centos创建一个镜像,里面带vim软件

Dockerfile

FROM centos:7
MAINTAINER lqz
WORKDIR /home
RUN yum install -y vim
RUN mkdir lqz
ADD ./xx.txt ./yy.txt

构建镜像

docker build -t='centos_lqz_vim' .

制作django项目的镜像,运行

# 步骤:
	-1 books项目准备好
    -2 在项目路径下编写Dockerfile
        FROM python:3.8
        MAINTAINER lqz
        WORKDIR /soft
        COPY ./requirements.txt /soft/requirements.txt
        RUN pip install -r requirements.txt -i https://pypi.doubanio.com/simple
        CMD ["python","manage.py","runserver","0.0.0.0:8080"]
        
    -3 把books代码提交到git
    -4 部署项目的机器,clone 项目
    	git clone https://gitee.com/liuqingzheng/books.git
    -5 cd books 文件夹下,执行构建镜像命令
    	docker build -t='django_books' .
    -6 有个镜像django_books,运行成容器
		docker run -id --name=books -v /root/books:/soft -p 8080:8080 books_django:latest
        
   -7 win操作系统的浏览器中访问虚拟机地址,就可以访问项目了

	-8 继续开发项目,改了代码,提交到git
    -9 部署项目的机器,拉去最新代码
    -10 重启docker容器即可(第三方依赖变了)--》重写构建镜像,运行容器

标签:容器,部署,redis,简易,mysql,镜像,Docker,root,docker
From: https://www.cnblogs.com/joseph-bright/p/17599369.html

相关文章

  • docker 入门
    docker入门虚拟化技术介绍#虚拟化在计算机中,虚拟化(英语:Virtualization)是一种资源管理技术,是将计算机的各种实体资源,如服务器、网络、内存及存储等,予以抽象、转换后呈现出来,打破实体结构间的不可切割的障碍,使用户可以比原本的组态更好的方式来应用这些资源。这些资源的新虚拟......
  • Linux简易功能介绍
    Linux简易功能介绍虚拟机关键配置名词解释#虚拟⽹络编辑器说明桥接模式#可以访问互联⽹!!! 配置的地址信息和物理主机⽹段地址信息相同,容易造成地址冲突NAT模式#可以访问互联⽹!!! 配置的地址信息和物理主机⽹段地址信息不同,造成不了地址冲突仅主机模式#不可以......
  • Docker
    1.docker是一个快速交付应用,运行应用的技术 1.1docker可以将应用及其依赖和运行环境(系统依赖库)打包成一个镜像,可以移植到任意的linux系统上 1.2运行时利用沙箱技术让各个容器隔离,各个应用互不干扰,启动移动通过一条命令完成,方便快捷 ......
  • centos7.9 部署elasticsearch 7.17.8 集群
    准备基本环境名称ip地址cpu内存es监听端口redis-65110.0.2.18c64G9200redis-65210.0.2.28c64G9200redis-65310.0.2.38c64G9200搭建集群10.0.2.1主机配置基本环境#更新hosts文件cat/etc/hosts10.0.2.1 es-node-110.0.2.2 es-node-21......
  • 【Azure 环境】ARM部署模板大于4MB的解决方案及Linked Template遇见存储账号防火墙无
    问题一:在ADFPipeline部署ARMTemplate报错“Deploymentfailed--therequestcontentsizeexceedsthemaximumsizeof4MB”【解答】4MB是一个固定限制,不可以修改其大小。 如果Template文件太大,需要把拆分成多个后,通过LinkedTemplate的方式部署。 在部署的时候,ARM通过main......
  • F5 LTM 知识点和实验 8-配置和管理高可用性部署
    第八章:配置和管理高可用性部署设备集群(deviceserviceclustering)与许多关键网络和IT基础设施组件一样,BIGIP系统可以部署在高可用性(HA)配置中,以支持持续的应用程序交付,而不会在很长一段时间内中断服务。当前BIG-IP系统的HA功能主要由DSC(DeviceServiceClustering)特性提供。......
  • 【Azure 环境】ARM部署模板大于4MB的解决方案及Linked Template遇见存储账号防火墙无
    问题一:在ADFPipeline部署ARMTemplate报错“Deploymentfailed--therequestcontentsizeexceedsthemaximumsizeof4MB”【解答】4MB是一个固定限制,不可以修改其大小。 如果Template文件太大,需要把拆分成多个后,通过LinkedTemplate的方式部署。 在部署的时候,ARM通......
  • 使用Maven插件为SpringBoot应用构建Docker镜像
    Docker开启远程API用vim编辑器修改docker.service文件#生成证书opensslgenrsa-aes256-outca-key.pem4096opensslreq-new-x509-days365-keyca-key.pem-sha256-outca.pemopensslgenrsa-outserver-key.pem4096opensslreq-subj"/CN=localhost"-sha256-......
  • Docker 发布Jenkins
    更新系统:sudoaptupdatesudoaptupgrade安装必要的依赖:sudoaptinstallapt-transport-httpsca-certificatescurlsoftware-properties-common添加Docker官方的GPG密钥:curl-fsSLhttps://download.docker.com/linux/debian/gpg|sudogpg--dearmor-o/usr/......
  • Terraform 部署 Docker
    Terraform部署Docker文件目录结构./├──network#network目录,创建network│├──main.tf│├──outputs.tf│├──terraform.tfstate│├──terraform.tfstate.backup│└──versions.tf└──service......