部署的应用仅仅是简单应用程序,使用的是node管理的web应用,具体我也不是很会,当然也可以配置tomcat服务器。这里主要是学习docker。需要客户机和服务机,其中服务机必须要为Linux操作系统。逻辑大致分为以下:

  1. 在开发者PC中编写程序
  2. 使用git push将源码上传到服务器
  3. 服务器收到客户机的git push命令后,执行git hook
  4. 在git hook中创建docker镜像,并以容器运行

  1. 在客户机创建git项目

git init simpleapp  #初始化git仓库
cd simpleapp/ #切换到仓库目录

  2. 在客户机编写Node.js需要的文件并提交到git

  • app.js文件
var express = require('express');
var app = express();
app.get(['/','/index.html'],function(request,response){
response.send('Hello World.');
}
);
app.listen(80);

  • package.json文件
{
"name": "simpleapp",
"description": "Hello Docker",
"version": "0.0.1",
"dependencies": {
"express": "4.4.x"
}
}

  • 把编写的文件提交到git
git add app.js package.json  #添加到git
git commit -m "add source" #提交到git

  注意:git如果是新安装的需要配置名字和邮箱,具体命令为:git config --global user.name <姓名>,git config --global user.email <邮箱>。

  3. 编写Dockerfile并提交到git

  • Dockerfile文件
FROM ubuntu:latest

RUN mv /etc/apt/sources.list /etc/apt/sources.list_bak
RUN echo "deb http://mirrors.aliyun.com/ubuntu/ bionic main multiverse restricted universe\ndeb http://mirrors.aliyun.com/ubuntu/ bionic-backports main multiverse restricted universe\ndeb http://mirrors.aliyun.com/ubuntu/ bionic-proposed main multiverse restricted universe\ndeb http://mirrors.aliyun.com/ubuntu/ bionic-security main multiverse restricted universe\ndeb http://mirrors.aliyun.com/ubuntu/ bionic-updates main multiverse restricted universe\ndeb-src http://mirrors.aliyun.com/ubuntu/ bionic main multiverse restricted universe\ndeb-src http://mirrors.aliyun.com/ubuntu/ bionic-backports main multiverse restricted universe\ndeb-src http://mirrors.aliyun.com/ubuntu/ bionic-proposed main multiverse restricted universe\ndeb-src http://mirrors.aliyun.com/ubuntu/ bionic-security main multiverse restricted universe\ndeb-src http://mirrors.aliyun.com/ubuntu/ bionic-updates main multiverse restricted universe" > /etc/apt/sources.list
RUN apt update
RUN apt install -y nodejs npm
ADD app.js /var/www/app.js
ADD package.json /var/www/package.json
WORKDIR /var/www
RUN npm install
CMD nodejs app.js

   

  文件说明:

  FROM:表示是ubuntu:latest镜像作为基础镜像

  RUN:执行更换阿里源的操作,再然后是安装nodejs和npm软件

  ADD:把前面创建的app.js和package.json文件添加到镜像的/var/www目录下

  WORKDIR:切换后面RUN、CMD的执行目录

  RUN:执行npm install将安装package.json文件到Node.js模块

  CMD:设置用于在容器启动时利用nodejs运行app.js

  • 提交到git
git add Dockerfile  #添加到git
git commit -m "add Dockerfile" #git提交

  4. 在客户机创建ssh密钥

  执行命令ssh-keygen可以生成由RSA加密算法的非对称密钥,路径默认,密码为空就可以了。

ssh-keygen  #选用默认方式生成非对称密钥

  可以看到生成的id_rsa私钥和id_rsa.pub公钥文件。

  5. 在服务机上安装git和Dicker并创建git项目

  我这里的服务机是虚拟机,也是Ubuntu系统。执行命令:

sudo apt install git  #在服务机上安装git
sudo apt install docker.io #在服务机上安装docker
git init ~/文档/simpleapp #初始化git仓库
cd ~/文档/simpleapp #切换到仓库目录

  6. 把客户机生成的公钥文件添加到服务机

  在服务机/home/用户目录上创建.ssh目录,并设置权限:

mkdir ~/.ssh  #创建目录
sudo chmod u+rwx ~/.ssh #为当前用户添加读、写和执行权限

  然后把客户机生成的id_rsa.pub文件内容复制到服务机.ssh目录下的authorized_keys文件中,并添加读写权限。(这里的公钥文件内容只适合我这里的非对称密钥)

echo "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDCMoyR+tfOqbRNvWW1mofxsOWHukYhBtwfAJNJmwb16pZ4Kj/ErvmvV7mromt3+Oj/GSRIHPjf2SXcS+IHiO1LXCvgwQ7NIpx1W/tDUhL5Eg17A15Hs6x8AvGpJ8K6f5DQ8I0jKg3JOvhAj+sw7OFlN5dte1Dzs0fEyRp6Ji/m6HTM/T1plHkQZ0PCH8yE9JfDF/0ReAbcNhOQeWFgV2f/mhiGdnVV0MvyMyA5Df/kdr+IlrTHkSrz9Ijz88cyz7QYau4NgTxKxM7S9qG8WyjNnpbbrt6ORFxYhSIRgPz+U05PbiV2Iuuwte20rLwFCKFy+WmFqKVgCE9Mf5EEthXV lollipop@lollipop-MS-7850" > ~/.ssh/authorized_keys
sudo chmod u+rw ~/.ssh/authorized_keys #为当前用户添加读写权限

  7. 在服务机上设置git hook的post-receive文件

  在服务机的simpleapp/.git/hooks目录下创建post-receive脚本文件,这个文件在接收到客户机的git push命令后会自动执行。

vim ~/文档/simpleapp/.git/hooks/post-receive  #vim编辑post-receive文件

  在post-receive文件填入以下内容:

#!/bin/bash
APP_NAME=simpleapp
APP_DIR=$HOME/文档/$APP_NAME GIT_WORK_TREE=$APP_DIR git checkout -f cd $APP_DIR
docker build --tag $APP_NAME:latest .
docker stop $APP_NAME
docker rm $APP_NAME
docker run -d --name $APP_NAME -p 80:80 $APP_NAME:latest

  文件说明:

  APP_NAME:当前应用程序的名称,需要和git仓库名相同

  APP_FIR:设置仓库目录的路径

  git checkout -f:把推送的源代码保存到仓库,需要设置GIT_WORK_TREE变量

  cd:转到仓库目录

  docker:进行创建镜像,运行镜像等操作。

  文件创建完成后,为其添加可执行权限:

sudo chmod +x ~/文档/simpleapp/.git/hooks/post-receive

  

  为了在服务机上能不添加sudo就可以执行docker命令,还需要在服务机上执行命令:

sudo usermod -aG docker ${USER}  #添加docker用户组并把当前用户添加近组
sudo docker service restart #重启docker服务
reboot #重启

  注意要重启,我这实验时注销并不起作用,唯有重启才起作用。重启后,执行随意的docker命令,如docker images看看有没有成功可以判断是否可以不加sudo执行docker命令。如下图所示为成功的:

  8. 在客户机尝试推送代码

  首先在客户机上添加远程仓库的地址,执行命令:

git remote add origin qbs409@192.168.1.246:文档/simpleapp #git添加服务机的仓库地址

  命令用法:git remote add origin <服务机用户名>@<服务机IP或域名>:服务机用户目录下的git仓库目录。 

  然后开始推送仓库到服务机,执行命令:

git push -u origin master

  发现服务机拒绝了,看到提示有说设置receive.denyCurrentBranch配置成ignore,参考https://www.cnblogs.com/cosiray/archive/2012/06/01/2530967.html,在服务机的simpleapp目录上编辑修改.git/config文件,在后面添加如下代码:

[receive]
denyCurrentBranch = ignore

  修改完成后,再回到客户机,把仓库推送到服务机上,执行命令:

git push -u origin master

                          ...

  

  可以看到推送成功了,并且看到服务机上执行了CMD nodejs app.js,这时可以尝试浏览器访问服务器看看是否成功运行程序。在客户机上的浏览器输入192.168.1.246:80,我这里的服务机ip地址是192.168.1.246,程序端口上面设置的是80。

  可以看到程序运行成功,这样服务器就可以自动运行每一次提交给它的源码了。

  9. 在服务机上查看docker的信息

  程序能够运行,是因为服务器成功创建了镜像并且成功运行了docker容器,在服务器上执行命令:

docker images  #查看镜像
docker ps #查看运行的容器

  可以看到创建的simpleapp镜像和容器simpleapp。

Docker学习笔记之向服务器部署应用程序的更多相关文章

  1. Docker学习笔记_04 Rancher的部署安装(编排选用K8S)

    原文地址:http://dbase.cc/2018/01/12/docker/04_rancher的部署安装/ 为什么要使用Rancher Rancher是一个开源的企业级容器管理平台.通过Ranch ...

  2. [学习笔记]Linux环境下部署 .Net5 程序

    ​公司的项目需要部署到一台公网的linux服务器,以便同事们测试小程序. 目标服务器是新搭建的CentOS 8虚拟机,以非docker的方式部署.现记录过程便于日后部署至项目甲方的服务器上,因为甲方的 ...

  3. Docker学习笔记之-部署.Net Core 3.1项目到Docker容器,并使用Nginx反向代理(CentOS7)(一)

    上一节演示如何安装Docker,链接:Docker学习笔记之-在CentOS中安装Docker 本节演示 将.net core 3.1 部署到docker容器当中,并使用 Nginx反向代理,部署平台 ...

  4. Docker学习笔记 - Docker容器内部署redis

    Docker学习笔记(2-4)Docker应用实验-redist server 和client的安装使用 一.获取redis容器(含客户端和服务端) 二.创建服务端容器 1.在终端A中运行redis- ...

  5. Docker学习笔记 — Docker私有仓库搭建

    Docker学习笔记 — Docker私有仓库搭建   目录(?)[-] 环境准备 搭建私有仓库 测试 管理仓库中的镜像 查询 删除 Registry V2   和Mavan的管理一样,Dockers ...

  6. Docker学习笔记之一,搭建一个JAVA Tomcat运行环境

    Docker学习笔记之一,搭建一个JAVA Tomcat运行环境 前言 Docker旨在提供一种应用程序的自动化部署解决方案,在 Linux 系统上迅速创建一个容器(轻量级虚拟机)并部署和运行应用程序 ...

  7. docker~学习笔记索引

    回到占占推荐博客索引 使用docker也有段时间了,写了不少文章与总结,下面把它整理个目录出来,方便大家去学习与检索! docker~学习笔记索引 docker~linux下的部署和基本命令(2017 ...

  8. golang学习笔记9 beego nginx 部署 nginx 反向代理 golang web

    golang学习笔记9 beego nginx 部署 nginx 反向代理 golang web Nginx 部署 - beego: 简约 & 强大并存的 Go 应用框架https://bee ...

  9. Docker 学习笔记一

    Docker 学习笔记一 1.Docker是什么?         Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源.让开发者打包他们的应用以及依赖包到一 ...

随机推荐

  1. nginx根据http请求,将JSON的请求转发到后端,将非JSON请求,转发到前端

    nginx.conf worker_processes 1; events { worker_connections 1024; } http { include mime.types; defaul ...

  2. Day1 字符串格式化

    1.占位符方式:占位符: %d 整数 %012d 数字位数至少长度为12位,不足的前面加0填充. >>> 'Hello,%s,%012d' % ('a',12345678901234 ...

  3. Day1 字符编码及编码函数

    ord() 函数 获取字符的整数表示chr() 函数 把整数编码转换为对应字符'\十六进制编码\十六进制编码' 可以将字符的整数编码使用十六进制的方式这样写Python字符串类型为str,在内存中以u ...

  4. MyBatis详细源码解析(上篇)

    前言 我会一步一步带你剖析MyBatis这个经典的半ORM框架的源码! 我是使用Spring Boot + MyBatis的方式进行测试,但并未进行整合,还是使用最原始的方式. 项目结构 导入依赖: ...

  5. Jackson:我是最牛掰的 Java JSON 解析器(有点虚)

    在当今的编程世界里,JSON 已经成为将信息从客户端传输到服务器端的首选协议,可以好不夸张的说,XML 就是那个被拍死在沙滩上的前浪. 很不幸的是,JDK 没有 JSON 库,不知道为什么不搞一下.L ...

  6. yii2 设置的缓存无效,返回false,不存在

    为了那些因为标题点进来的小伙伴,我直接把问题解决方案写在开头: 问题描述, $cache->add($key,'value',1800);这样设置了值后,后面无论怎么取这个$key,取出来的结果 ...

  7. MySQL的修仙者之旅,不来看看你的修为如何吗?

    目录 因为我个人比较喜欢看修仙类的小说,所以本文的主体部分借用修仙者的修为等级,将学习旅程划分成:练气.筑基.结丹.元婴.化神.飞升六个段位,你可以看下你大概在哪个段位上哦! 本文目录: 我为什么要写 ...

  8. 企业微信JS-SDK实现会话聊天功能

    vue引入企业微信JS-SDK实现会话聊天功能 这两天在做一个对接企业微信实现会话聊天的功能, 发现企业微信文档这块儿做的不是特别详细,网上搜索也没找到特别完整的流程. 期间也踩了不少的坑, 在此进行 ...

  9. DotfuscatorPro防止反编译&ILSpy反编译

    DotfuscatorPro_4.9可以防止你的.NET软件被反编译,可以在一定程度上防止你的软件被反编译.现在很多软件都有被反编译的现象,虽然不能做到百分百的防范,但是你至少可以先做些技术上的处理, ...

  10. html中table表格标题固定表数据行出现滚动条

    需求 web系统中有的用户不喜欢分页,希望数据能在一个页面中全部显示出来. 但是页面中是有滚动条的,当查看下面的数据时就不知道数据行中的列对应的是哪个标题的列. 也就是无法知道这个列是什么数据. 所以 ...