前言

大家好,我是jack xu,本篇是我在今日头条的首秀,我的英文名来源于jack ma,马云,所以大家也可以叫我徐云,即我希望像马云一样富有、成功,另外我名字中的杰与jack也是谐音关系。

今天给大家带来的是一篇docker的科普入门篇,本文不会像其他文章一样进行枯燥无味的纯概念性介绍,docker是如何如何的好,用了docker就如何如何的6,而是以一个项目实战让大家从感性上认识一下docker,在做项目的过程中了解熟悉一些命令,然后在去看概念的东西会更容易上手。

本次实战的架构图如下,搭建一套Nginx+Spring Boot+MyBatis+MySQL的docker环境。

工具准备

首先我们需要一台centos的机器操作,先吹下牛啊,因为我有钱任性,买了三台云服务器,平时搭一些redis、kafak、zk等中间件做实验用,一年期的,也快到期了,小伙们如果不像我这么任性的话可以用vmware或者virtualbox等虚拟机操作哦,我这里选的是第一台106.12.84.31的机器。

安装docker

工欲善其事必先利其器,既然要玩docker,那肯定是要先装docker是吧,这里我也放了个菜鸟的链接,很简单,大家照着操作就行。菜鸟链接

1、卸载之前的docker(可选)sudo yum remove docker                   docker-client                   docker-client-latest                   docker-common                   docker-latest                   docker-latest-logrotate                   docker-logrotate                   docker-engine    2、 安装必要的依赖sudo yum install -y yum-utils     device-mapper-persistent-data     lvm23、设置docker仓库  [设置阿里云镜像仓库可以先自行百度,后面课程也会有自己的docker hub讲解]sudo yum-config-manager       --add-repo       https://download.docker.com/linux/centos/docker-ce.repo4、安装dockersudo yum install -y docker-ce docker-ce-cli containerd.io5、启动dockersudo systemctl start docker6、测试docker安装是否成功sudo docker run hello-world复制代码

安装完docker后是不是万事大吉,其实不然,还差一步,当我们在拉取镜像的时候就会如下所示,卡主不动了,等几个小时可能也不会好,这时候就需要我们安装镜像加速器。

[root@localhost ~]# docker pull mysqlUsing default tag: latestlatest: Pulling from library/mysql0a4690c5d889: Already exists 98aa2fc6cbeb: Already exists 0777e6eb0e6f: Already exists 2464189c041c: Already exists b45df9dc827d: Already exists b42b00086160: Already exists bb93567627c7: Already exists b9125bcebe66: Already exists d263609b23c7: Downloading [=============================>                     ]  27.63MB/46.88MBc9adffb2afb9: Download complete a555d31b3e6c: Download complete 9524d219b6db: Download complete复制代码

登录阿里云的官网,注册个账号,然后点击左侧菜单的最下面,如我用红框标出来的,把镜像加速器配置好即可,这个原理就像我们拉取maven的jar包时一样,也会配阿里云的仓库,所以让我们一起感谢阿里,造福码农。

配置好以后,就可以开始我们后面的操作了,我们从后往前开始安装,即mysql->spring boot->nginx

科普

docker中有两个重要的概念,一个是image,一个container,image就是镜像,什么是镜像。类比一下,就是我们在重装系统的时候都要用ghost镜像,这是由人家制作好的,这个镜像上可能有各种各样的软件,而把这个镜像在每一台电脑上把系统重装好,就是一个实例,就是我们所说的container。一个image可以生成多个container。

安装MySQL

1)、首先创建自定义网桥,为什么要创建网桥,因为这么多容器都是要放在这一个网段里的,而在不同网段上的container是ping不通的

docker network create --subnet=172.18.0.0/24 jack-netdocker network ls                 [查看所有网络]docket network inspect jack-net   [查看详情]docker network rm jack-net        [删除]复制代码

2)、拉取镜像,不加版本默认拉取最新的,也可以指定版本mysql:5.7

docker pull mysql复制代码

3)、创建volume,为什么需要volume,你可以理解为持久化,mysql保存的数据都是存在磁盘上的,我们需要把docker中生成的数据挂载到宿主机上

docker volume create v1复制代码

4)、创建mysql容器,-d是后台运行,--name是给container起的名字,-v就是挂载,-p是端口映射,docker中的3306映射到宿主机的3306,-e是密码,--net是使用哪个网段,--ip是在这个网段中用的地址

docker run -d --name jack-mysql -v v1:/var/lib/mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=jack123 --net=jack-net --ip 172.18.0.6 mysql复制代码

5)、接下来我们来做测试,用navicate连接,执行.mysql文件新建表

name:jack-mysqlip:106.12.84.31       [宿主机的ip]   端口:3306             [宿主机端口]user:rootpassword:jack123      [创建container时我们设的密码]复制代码

                                     连接成功

create schema jack_springboot collate utf8mb4_0900_ai_ci;use jack_springboot;create table t_user(id int not nullprimary key,username varchar(50) not null,password varchar(50) not null,number varchar(100) not null);复制代码

                                     建表语句

                                     插入一条数据

mysql到此就准备好了

安装Spring Boot项目

1)、首先搭建一个springboot +mybatis项目,这个很简单,简单的三层架构,这里我放上我github的地址,github.com/xuhaoj/spri… 大家可以star一下

                                    项目结构

这里写的是mysql container的ip地址和端口,因为在同一个网段中,容器之间不仅可以通过ip访问,也可以通过名称,因为内置了一个DNS的解析,即jdbc:mysql://my-mysql:3306/xxxxx

2)、将项目进行打包,在项目的target下找到"springboot-mybatis-0.0.1-SNAPSHOT.jar"

mvn clean package -Dmaven.test.skip=true复制代码

3)、在centos7创建一个文件夹

mkdir -p xhj/springboot-mybatis复制代码

4)、安装文件传输工具,将"springboot-mybatis-0.0.1-SNAPSHOT.jar"上传到该目录下

yum install lrzszrz -y复制代码

5)、创建并且编写dockerfile,好,这里的关键来了,我们平时生成container是把别人已经制作好的image拉取下来,而现在这是我们自己的项目,所以这个image需要我们自己做,而制作的原材料就是dockerfile

vi DockerfileFROM openjdk:8MAINTAINER itcrazy2016LABEL name="springboot-mybatis" version="1.0" author="itcrazy2016"COPY springboot-mybatis-0.0.1-SNAPSHOT.jar springboot-mybatis.jarCMD ["java","-jar","springboot-mybatis.jar"]复制代码

6)、生成image镜像

docker build -t sbm-image .复制代码

查看一下,我们自己的image已经生成好了

7)、最后一步,通过我自己制作的image生成三个springboot项目容器,这里的命令和生成mysql的一样,不在重复说明

docker run -d --name sb01 -p 8081:8081 --net=jack-net --ip 172.18.0.11 sbm-imagedocker run -d --name sb02 -p 8082:8081 --net=jack-net --ip 172.18.0.12 sbm-imagedocker run -d --name sb03 -p 8083:8081 --net=jack-net --ip 172.18.0.13 sbm-image复制代码

查看一下,至此,我们自己项目和mysql的container都已经生成好了

安装Nginx

好,现在是最后一步了,胜利的曙光就在眼前

1)、在宿主机中xhj/nginx目录下新建一个nginx.conf文件,这里的ip和端口还是container自己的ip和端口,不要填写宿主机的

user nginx;worker_processes  1;events {    worker_connections  1024;}http {    include       /etc/nginx/mime.types;    default_type  application/octet-stream;    sendfile        on;    keepalive_timeout  65;        server {        listen 80;        location / {         proxy_pass http://balance;        }    }        upstream balance{          server 172.18.0.11:8081;        server 172.18.0.12:8081;        server 172.18.0.13:8081;    }    include /etc/nginx/conf.d/*.conf;}复制代码

2)、拉取nginx镜像

docker pull nginx复制代码

3)、创建nginx容器,通过挂载的方式,container中的配置文件就是读取我们宿主机中创建的配置文件,so easy

docker run -d --name my-nginx -p 80:80 -v /xhj/nginx/nginx.conf:/etc/nginx/nginx.conf --network=jack-net --ip 172.18.0.10 nginx复制代码

4)、最后我们用postman来验证一下,这里nginx配的是80端口,http默认端口就是80,所以我不需要在加端口

http://宿主机ip/user/listall复制代码

至此,大功告成,我们的docker初体验圆满成功!

总结

小伙伴看完这篇文章有没有感觉很神奇,区区几个命令就把这么多东西给部署起来了。而在此之前就是各种各样的安装,繁琐的配置,试想该项目中只是用了mysql,而真正项目中还会用到redis、kafak、zookeeper等中间件的使用,这些东西还不能只是单机,还要考虑集群高可用,那无异于运维成本是相当大的,而使用了docker就会简单很多。

大家可以跟着做一下,或者不愿意做的话看完这篇文章至少会对docker有一个感性的认识,很多时候我们做java开发,只要我们代码往上一推,过一会编译部署以后新功能就能访问到了,这一系列的CI/CD背后就是强大的工具技术支持jenkins、docker、k8s,这些运维团队都帮我们做好了,俗话说技多不压身,我们在做开发的同时还需要了解一些运维知识来充实自己。

最后我们要保持一个空杯心态,小伙伴看完以后可能会觉得运维也不过如此,其实不然,这只是冰山一角,真实中的运维场景会比这复杂很多,比如

  • 今天这多container都是一个个敲命令,重复工作很多,也很累,尤其是端口、映射、挂载啊多了以后完全分不清,这时候就要用到docker compose技术,这是相当于一个yml文件,可以一键帮我们部署
  • 而且这么多container都是部署在单机上,当container很多的时候一台机器是扛不住,而且很多时候我们会做高可用,存在多机部署的情况,这就需要用到docker swarm和k8s等容器编排技术
  • 本项目中用的mysql也是单机,而如果我们要做mysql集群的话还需要用到haproxy+pxc技术 .....

总之,要学的还有很多,感谢大家的收看,如果你觉得不错,请动手点个赞。

ping不通docker_初识docker相关推荐

  1. linux网络连接问题(ping不通)

    1.可能是路由信息不对. 先route -n查看路由信息. 如果没有当前子网的网络号,可以添加: route add default gw 网关 网关一般是网络号的最后一部分为1 2.ping htt ...

  2. ping不通是不是就真不通?

    ping是用的ICMP协议. 如果ACL,防火墙中禁止了ICMP协议之后.也是ping不同的! 例如,很多服务器的网站.虽然ping不通.但是照样可以登上.可以访问其他端口. 但是,如果没有其他禁止措 ...

  3. ping 不通 华为三层交换机vlan_华三两台三层华为交换机 vlan互访 配置

    满意答案 罗志19850318 2015.05.17 采纳率:40%    等级:12 已帮助:3055人 (1)在二层交换机上配置VLAN2.VLAN3,分别将端口2.端口3划到VLAN2.VLAN ...

  4. nat模式物理机ping不通虚拟机

    今天在虚拟机搭建了一个CMS网站,在物理机上无法访问,检查发现,网络根本ping 不通,经研究排查,发现主要是下面几个问题,接下来给大家介绍一下 物理机ip[桥接]网段:192.168.3.x 虚拟机 ...

  5. 无法上外网, ping网关ping不通的解决——arp命令

    转自:http://jingyan.baidu.com/article/3c48dd34873909e10be35894.html 转自:http://man.linuxde.net/arp 用来管理 ...

  6. linux下ping不通问题的说明与解决(DNS配置丢失)

    linux下ping不通问题的说明与解决(DNS配置丢失) 参考文章: (1)linux下ping不通问题的说明与解决(DNS配置丢失) (2)https://www.cnblogs.com/chou ...

  7. 主机ping不通ubuntu虚拟机的解决方法

    主机ping不通ubuntu虚拟机的解决方法 参考文章: (1)主机ping不通ubuntu虚拟机的解决方法 (2)https://www.cnblogs.com/zzgyq/p/8480674.ht ...

  8. 局域网下两台电脑ping不通

    参考:https://blog.csdn.net/sinat_38718975/article/details/79866557 1.在同一网段内 假设电脑A.B均在192.168.0.X的网段内,两 ...

  9. git 无法拉取项目,本地ping不通github的解决办法(详解)

    一.遇到的问题 本地在从github上拉取项目的时候,一直卡着,然后过个2分钟就报错,连接超时.问题是我前几天还能git pull项目呢,百思不得其解.后来本地浏览器访问github,得,连全世界最大 ...

最新文章

  1. 洛谷 P3302 [SDOI2013]森林 主席树+启发式合并
  2. jQuery队列控制方法详解queue()/dequeue()/clearQueue()
  3. 1.15 Java访问控制修饰符(public、 private、protected 和 friendly)
  4. Spring Batch 专题
  5. 手把手实现YOLOv3(三)
  6. android 百度移动搜索 url 参数,百度刷站内快排算法参数-百度搜索URL参数比较详解...
  7. 关于Java中的HashMap
  8. 抠图为什么要用绿布_逆天抠图,Photoshop 2020天神下凡
  9. mysql ip比较大小_解决mysql进行ip字符串比较问题
  10. php中vc14是什么意思,VC9、VC11、VC14、VC15是啥?
  11. C语言#include<stdio.h>什么意思?
  12. Java——图形 继承Shapes(形状)计算周长,面积。
  13. 镜像网站 | 淘宝镜像网站
  14. 2022完整版青龙面板对接傻妞机器人
  15. mybatis的association以及collection的用法
  16. Hexo博客主题Next添加动态线条背景canvas_nest
  17. element-ui表单下拉选项展示来自数据库的内容
  18. 2016年11月5日学习总结
  19. 日本区块链联盟助推日本区块链发展
  20. 华为网吧服务器型号,网吧服务器推荐

热门文章

  1. 智能音箱 之 麦克风参数介绍
  2. 史上超全halcon常见3D算子汇总(一)
  3. nohup命令输出日志_逼格高又实用的Linux高级命令,开发运维都要懂
  4. openCV中waitKey函数介绍
  5. android功耗iphone,是心目中的安卓小屏旗舰吗?iPhone 8尺寸大小,4000mAh电池容量...
  6. 多个装饰器装饰一个函数
  7. 使用字符缓冲流读取数据
  8. 《大话设计模式》--模板模式
  9. Python---时间函数
  10. Android Listview 性能优化