您好!欢迎来到源码码网

Linux服务器 CentOS8系统用Docker部署开源项目Tcloud的教程

  • 建站技巧
  • 来源:源码码网
  • 编辑:admin
  • 时间:2020-02-05 22:21
  • 阅读:565

一、安装Docker

1、我是虚拟机装的Centos7,linux 3.10 内核,docker官方说至少3.8以上,建议3.10以上(ubuntu下要linux内核3.8以上)

root账户登录,查看内核版本如下

uname -a

2、把yum包更新到最新

yum update

(期间要选择确认,输入 y 即可)

3、安装需要的软件包,yum-util 提供yum-config-manager功能,另外两个是devicemapper驱动依赖的

yum install -y yum-utils device-mapper-persistent-data lvm2

4、设置yum源

yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo(阿里仓库)

5、可以查看所有仓库中所有docker版本,并选择特定版本安装

yum list docker-ce --showduplicates | sort -r

6、安装Docker,命令:yum install docker-ce-版本号,我选的是docker-ce-18.03.1.ce,如下

yum install docker-ce-18.03.1.ce

(期间要选择确认,输入 y 即可)

7、启动Docker,命令:systemctl start docker,然后加入开机启动,如下:

systemctl start docker #启动docker

systemctl enable docker #设置docker为开机自启[/code][code]sudo docker run --rm hello-world #启动docker中的hello-word

8、如果看到如图:

Docker部署开源

则说明安装doceker成功

二、接下来安装doceker-compose

1、运行以下命令下载Docker Compose的当前稳定版本:

sudo curl -L "https://github.com/docker/compose/releases/download/1.25.0/docker-compose-$(uname
 -s)-$(uname -m)" -o /usr/local/bin/docker-compose

2、将可执行权限应用于二进制文件:

sudo chmod +x /usr/local/bin/docker-compose

3、注意:如果命令docker-compose在安装后失败,请检查您的路径。您也可以创建指向/usr/bin或路径中任何其他目录的符号链接。

例如:

sudo ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose

4、检查docker-compose 是否安装成功

doceker-compose --version

三、安装与配置Git

1、在Linux上是有yum安装Git,非常简单,只需要一行命令:

yum -y install git

输入:

git --version

查看Git是否安装完成以及查看其版本号

2、配置git:

git config --global user.name "xxx"git config --global user.email "xxxxx@xx.com"git config 
--global core.autocrlf falsegit config --global gui.encoding utf-8

3、执行下面的命令,一直回车,直到结束

ssh-keygen -t rsa -C xxxxx@xxx.com

4、生成ssh key

cat ~/.ssh/id_rsa.pub

5、登陆GitHub,点击setting>SSHand GPG keys>New SSH Key 将生成的密钥复制到Key中即可

6、测试是否配置成功

ssh -T git@github.com

7、出现这样一段话,即证明配置成功。

Hi RoninLee! You've successfully authenticated, but GitHub does not provide shell access.

四、后端部署

、运行以下命令拉起源码:

git clone https://github.com/bigbaser/TcloudServer.git

2、进入到TcloudServerdeploy目录下,使用以下命令,拉取所有(等待一会,拉取时间较长)

docker-compose pull

3、然后修改local_config.py文件,

# 这里的账号密码是在docker-compose.yml中配置的,改成以下
SQLALCHEMY_DATABASE_URI = 'mysql://root:tc123456@mysql:3306/demo?charset=utf8'

4、再初始化kong的数据库(如果报错,再执行一次,成功的话会显示Database is up-to-date)

$ sudo docker-compose up -d kong_database
// 容器启动以后,数据库会本地挂载到 ./volumes/kong_database 里面
// 但由于权限问题,初始化数据库会失败,所以要先对该文件赋予权限
$ sudo chmod -R 777 ./volumes/kong_database
$ sudo docker-compose run --rm kong kong migrations bootstrap

5、然后启动所有项目

$ sudo docker-compose up -d

6、查看启动状态

$ sudo docker-compose ps

7、如果所有状态均为up,则运行正常,否则查看日志

sudo docker logs <name>查看日志

8、打开konga(kong的管理页面,http://localhost:9001),注册账号并登录,再新建连接,地址为http://kong:8001

Docker部署开源

五、前端部署

1、安装node环境

从CentOS储存库安装Node.js和npm

可以从标准CentOS存储库中安装Node.js和npm。

通过运行以下命令列出提供nodejs软件包的模块:

yum module list nodejs

要在CentOS系统上安装默认的Node.js软件包,请输入:

sudo yum module install nodejs

输入以下命令:

node --version #检查node 是否安装成功
npm --version #检查 npm 是否安装成功

2、使用以下命令拉取前端代码:

git clone https://github.com/bigbaser/Tcloud.git

3、在前端项目的根目录下执行:npm install 安装依赖包

4、安装依赖包如报以下错:

Docker部署开源

解决办法:

4.1、输入以下命令:

npm install -g cnpm --registry=https://registry.npm.taobao.org

4.2、建立软链接:

sudo ln -s {此处为你安装npm的路径}.npm-global/bin/cnpm /usr/local/bin/cnpm

4.3、输入:

cnpm --version 检查是否安装成功。

5、修改config/dev.env.js与index.js文件中的BASE_URL 地址为http://0.0.0.0

Docker部署开源

6、运行前端项目:

npm run dev

7、在非 localhost 域名下登录不成功,可以打开开发者工具,查看Application下的Cookies是否有JWT_TOKEN_TCLOUD_DEV。

如果没有,找到前端项目 Tcloud/src/store/modules/login.js,修改第57行,把

domain: process.env.NODE_ENV === 'development' ? 'localhost' : COOKIE_DOMAIN
修改为:
domain: COOKIE_DOMAIN

然后修改 config 下的 dev.env.js,把 COOKIE_DOMAIN 改成前端当前访问域名即可。


六、报错总结:

一、docker pull 镜像时报错:

1、

ERROR: Get https://registry-1.docker.io/v2/: dial tcp: lookup registry-1.docker.io 
on such host

2、

ERROR: Get https://registry-1.docker.io/v2/: dial tcp: lookup registry-1.docker.io 
on xxx.xxx.xxx.xxx:xxxx: lame referral

3、

Error response from daemon: Get https://index.docker.io/v1/search?q=sameersbn&n=25: 
dial tcp: lookup index.docker.io on 192.168.65.1:53: read udp 
192.168.65.2:45190->192.168.65.1:53: i/o timeout

Error response from daemon: Get https://registry-1.docker.io/v2/: net/http: 
request canceled while waiting for connection 
(Client.Timeout exceeded while awaiting headers)

二、分析问题:

问题1、2这个是因为DNS域名没有解析的原因。

问题3 网络连接超时,这情况涉及到很多因素。

三、解决办法:

问题:1、2:

vi /etc/resolv.conf 增加一行DNS地址:例如:nameserver 114.114.114.114 (此方法服务器重启之后会失效。参考方法2:vi /etc/sysconfig/network-scripts/ifcfg-ens33打开网卡配置文件,在配置文件中添加:DNS1=”8.8.8.8”,DNS2=”114.114.114.114”)

保存之后,继续执行拉取镜像的命令,即可!

问题:3:

3.1通过dig @114.114.114.114 registry-1.docker.io找到可用IP

3.2尝试修改/etc/hosts强制docker.io相关的域名解析到其它可用IP

3.3保存之后重试即可: docker search sameersbn

附一些常用Docker命令,更多命令详解,请访问:http://www.docker.org.cn/dockerppt/106.html:

----------------- docker ps 查看当前正在运行的容器

----------------- docker ps -a 查看所有容器的状态

----------------- docker start/stop id/name 启动/停止某个容器

----------------- docker attach id 进入某个容器(使用exit退出后容器也跟着停止运行)

----------------- docker exec -ti id 启动一个伪终端以交互式的方式进入某个容器(使用exit退出后容器不停止运行)

----------------- docker images 查看本地镜像

----------------- docker rm id/name 删除某个容器

----------------- docker rmi id/name 删除某个镜像

----------------- docker run --name test -ti ubuntu /bin/bash 复制ubuntu容器并且重命名为test且运行,然后以伪终端交互式方式进入容器,运行bash

----------------- docker build -t soar/centos:7.1 . 通过当前目录下的Dockerfile创建一个名为soar/centos:7.1的镜像

----------------- docker run -d -p 2222:22 --name testsoar/centos:7.1 以镜像soar/centos:7.1创建名为test的容器,并以后台模式运行,并做端口映射到宿主机2222端口,P参数重启容器宿主机端口会发生改变


参考地址:https://www.jb51.net/article/179049.htm


特别声明:
1、如无特殊说明,内容均为本站原创发布,转载请注明出处;
2、部分转载文章已注明出处,转载目的为学习和交流,如有侵犯,请联系客服删除;
3、编辑非《源码码网》的文章均由用户编辑发布,不代表本站立场,如涉及侵犯,请联系删除;
全部评论(0)
推荐阅读
  • bootstrap ui框架能用在uniapp中吗?
  • bootstrap ui框架能用在uniapp中吗?
  • BootstrapUI框架通常是前端开发中的一种工具,它提供了一套预定义的CSS样式和组件,用于快速构建响应式布局的网页。然而,UniApp是一个使用Vue.js开发跨平台应用的框架,它可以用来开发iOS、Android、以及各种小程序和H5应用。
  • 互动社区
  • 来源:源码码网
  • 编辑:热度建站
  • 时间:2024-04-12 00:04
  • 阅读:179
  • css实现banner图由中心点动态放大效果
  • css实现banner图由中心点动态放大效果
  • 在日常的网页设计中,为了让网页增加一定的特效以达到交互的目的,我们尝尝会在网页中使用一些动画效果。今天来说说实现banner图由中心点动态放大效果,实现这个效果需要用到css中的动画:animation​和关键帧:@keyframes,具体示例如下:
  • 源码教程
  • 来源:源码码网
  • 编辑:源码码网
  • 时间:2024-04-11 18:52
  • 阅读:192
  • countUp.js实现鼠标滑动到某个位置数字自动滚动增加的效果
  • countUp.js实现鼠标滑动到某个位置数字自动滚动增加的效果
  • 在网页开发中为了提升网页的交互效果,经常会用到使用js给网页增加一定的特效,下边就来说说使用js实现鼠标滑动到某个位置数字自动滚动增加的效果。其实这种效果有很多中解决办法,自己也可以去写,下边我们借助countUp.js来实现,关于这个js文件,我放在末尾:
  • 源码教程
  • 来源:源码码网
  • 编辑:源码码网
  • 时间:2024-04-08 09:20
  • 阅读:268
  • 响应式网页设计思路及注意事项
  • 响应式网页设计思路及注意事项
  • 一、什么是响应式网页响应式网页设计就是让网页具有根据设备类型应用CSS样式的能力。设计:设想、计划。设计就是把想法实现。网页设计:按照一定的设计思路布局网页内容。传统网页设计:都是针对PC端浏览器而设计的,不具备查询设备的能力,更不能对多种访问设备做出响应。传统网页设计的弊端:在移动互联网时代,传统的网页设计不适合多屏幕时代。响应式网页设计应运而生。响应式网页设计是一种设计网页的思想/方法。响应:指让我们的网页能够自动查询用户的访问设备
  • 源码教程
  • 来源:源码码网
  • 编辑:源码码网
  • 时间:2024-04-02 11:24
  • 阅读:175
  • css中rel的属性值都有哪些,分别代表什么意思
  • css中rel的属性值都有哪些,分别代表什么意思
  • 在HTML中,元素的rel属性用于定义当前文档与被链接文档之间的关系。这个属性在CSS的上下文中经常与样式表关联,但rel属性的用途远不止于此。以下是一些常见的rel属性值及其意义:1、stylesheet:表示被链接的文档是一个样式表。这通常用于链接CSS文件。
  • 源码教程
  • 来源:源码码网
  • 编辑:源码码网
  • 时间:2024-03-28 12:28
  • 阅读:305
联系客服
源码代售 源码咨询 素材咨询 联系客服
029-84538663
手机版

扫一扫进手机版
返回顶部