欢迎您访问365答案网,请分享给你的朋友!
生活常识 学习资料

如何从零开始搭建服务器

时间:2023-05-21

文章目录

前言

记录如何将一台空服务器搭建满足开发需要。

一、Docker是什么?

二、Docker搭建

1.安装与配置

2.配置 Docker 容器与镜像

3.Docker 常用命令

4.GUI 管理配置

三、Docker搭建Mysql数据库

1.建立镜像

2.一般来说数据库容器不需要建立目录映射

3.连接mysql

总结



前言


记录如何将一台空服务器搭建满足开发需要。

一、Docker是什么?

Docker作为一个软件集装箱化平台,可以让开发者构建应用程序时,将它与其依赖环境一起打包到一个容器中,然后很容易地发布和应用到任意平台中。

docker就是类似的理念。现在都流行云计算了,云计算就好比大货轮。docker就是集装箱。

1.不同的应用程序可能会有不同的应用环境,比如.net开发的网站和php开发的网站依赖的软件就不一样,如果把他们依赖的软件都安装在一个服务器上就要调试很久,而且很麻烦,还会造成一些冲突。比如IIS和Apache访问端口冲突。这个时候你就要隔离.net开发的网站和php开发的网站。常规来讲,我们可以在服务器上创建不同的虚拟机在不同的虚拟机上放置不同的应用,但是虚拟机开销比较高。docker可以实现虚拟机隔离应用环境的功能,并且开销比虚拟机小,小就意味着省钱了。2.你开发软件的时候用的是Ubuntu,但是运维管理的都是centos,运维在把你的软件从开发环境转移到生产环境的时候就会遇到一些Ubuntu转centos的问题,比如:有个特殊版本的数据库,只有Ubuntu支持,centos不支持,在转移的过程当中运维就得想办法解决这样的问题。这时候要是有docker你就可以把开发环境直接封装转移给运维,运维直接部署你给他的docker就可以了。而且部署速度快。3.在服务器负载方面,如果你单独开一个虚拟机,那么虚拟机会占用空闲内存的,docker部署的话,这些内存就会利用起来。总之docker就是集装箱原理。

二、Docker搭建

1.安装与配置

1.安装依赖包

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

2.设置阿里云镜像源

sudo yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

3.安装 Docker-CE

重建 Yum 缓存。安装 Docker-CE ,请执行一下命令进行安装:

sudo yum install docker-ce

4.启动 Docker-CE

sudo systemctl enable docker sudo systemctl start docker

5.[可选] 为 Docker 建立用户组

docker 命令与 Docker 引擎通讯之间通过 UnixSocket ,但是能够有权限访问 UnixSocket 的用户只有 root 和 docker 用户组的用户才能够进行访问,所以我们需要建立一个 docker 用户组,并且将需要访问 docker 的用户添加到这一个用户组当中来。

1、建立 Docker 用户组

sudo groupadd docker

2.添加当前用户到 docker 组

sudo usermod -aG docker $USER

6.镜像加速配置

这里使用的是 阿里云提供的镜像加速 ,登录并且设置密码之后在左侧的 Docker Hub 镜像站点 可以找到专属加速器地址,复制下来。

然后执行以下命令:

sudo mkdir -p /etc/dockersudo tee /etc/docker/daemon.json <<-'EOF'{ "registry-mirrors": ["你的加速器地址"]}EOFsudo systemctl daemon-reloadsudo systemctl restart docker

之后重新加载配置,并且重启 Docker 服务

systemctl daemon-reload systemctl restart docker

2.配置 Docker 容器与镜像

1.拉取镜像

拉取微软在 Docker 上的 aspnetcore 镜像:

docker pull microsoft/aspnetcore

之后执行以下命令查看是否拉取成功:

docker images

3.Docker 常用命令

1.拉取镜像

docker pull

2.删除容器

docker rm <容器名 or ID>

3.查看容器日志

docker logs -f <容器名 or ID>

4.查看正在运行的容器

docker ps docker ps -a # 为查看所有的容器,包括已经停止的。

5.删除所有容器

docker rm $(docker ps -a -q)

6.停止、启动、杀死指定容器

docker start <容器名 or ID> # 启动容器 docker stop <容器名 or ID> # 启动容器 docker kill <容器名 or ID> # 杀死容器

7.查看所有镜像

docker images

8.拉取镜像

docker pull <镜像名:tag> # 例如以下代码 docker pull sameersbn/redmine:latest

9.后台运行

docker run -d # 例如 docker run -d -p 127.0.0.1:33301:22 centos6-ssh

10.暴露端口

# 一共有三种形式进行端口映射docker -p ip:hostPort:containerPort # 映射指定地址的主机端口到容器端口# 例如:docker -p 127.0.0.1:3306:3306 映射本机3306端口到容器的3306端口docker -p ip::containerPort # 映射指定地址的任意可用端口到容器端口# 例如:docker -p 127.0.0.1::3306 映射本机的随机可用端口到容器3306端口docer -p hostPort:containerPort # 映射本机的指定端口到容器的指定端口# 例如:docker -p 3306:3306 # 映射本机的3306端口到容器的3306端口

11.映射数据卷

docker -v /home/data:/opt/data # 这里/home/data 指的是宿主机的目录地址,后者则是容器的目录地址

4.GUI 管理配置

这里推荐使用 Portainer 作为容器的 GUI 管理方案。

官方地址:https://portainer.io/install.html

安装命令:

docker volume create portainer_datadocker run -d -p 9000:9000 -v /var/run/docker.sock:/var/run/docker.sock -v portainer_data:/data portainer/portainer访问你的 IP:9000 即可进入容器管理页面。

访问你的 IP:9000 即可进入容器管理页面。

如下:


三、Docker搭建Mysql数据库

1.建立镜像

        (1)拉取官方镜像(我们这里选择5.7,如果不写后面的版本号则会自动拉取最新版)

docker pull mysql:5.7 # 拉取 mysql 5.7docker pull mysql # 拉取最新版mysql镜像

MySQL文档地址https://hub.docker.com/_/mysql/

        (2)检查是否拉取成功

$ sudo docker images

2.一般来说数据库容器不需要建立目录映射

sudo docker run -p 3306:3306 --name mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7

–name:容器名,此处命名为mysql-e:配置信息,此处配置mysql的root用户的登陆密码-p:端口映射,此处映射 主机3306端口 到 容器的3306端口

(1)如果要建立目录映射

duso docker run -p 3306:3306 --name mysql -v /usr/local/docker/mysql/conf:/etc/mysql -v /usr/local/docker/mysql/logs:/var/log/mysql -v /usr/local/docker/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7

-v:主机和容器的目录映射关系,":"前为主机目录,之后为容器目录

(2)查看 mysql 是否运行

docker ps

docker container ls

可以看到容器ID,容器的源镜像,启动命令,创建时间,状态,端口映射信息,容器名字

3.连接mysql

(1)进入docker本地连接mysql客户端

docker exec -it mysql bash mysql -uroot -p123456

(2)如果你的容器运行正常,但是无法访问到MySQL,一般有以下几个可能的原因:

防火墙阻拦

# 开放端口:$ systemctl status firewalld$ firewall-cmd  --zone=public --add-port=3306/tcp -permanent$ firewall-cmd  --reload# 关闭防火墙:$ sudo systemctl stop firewalld

需要进入docker本地客户端设置远程访问账号

$ sudo docker exec -it mysql bash$ mysql -uroot -p123456mysql> grant all privileges on *.* to root@'%' identified by "123456";mysql>FLUSH PRIVILEGES;

原理:

# mysql使用mysql数据库中的user表来管理权限,修改user表就可以修改权限(只有root账号可以修改)mysql> use mysql;Database changedmysql> select host,user,password from user;+--------------+------+-------------------------------------------+| host | user | password |+--------------+------+-------------------------------------------+| localhost | root | *A731AEBFB621E354CD41BAF207D884A609E81F5E || 192.168.1.1 | root | *A731AEBFB621E354CD41BAF207D884A609E81F5E |+--------------+------+-------------------------------------------+2 rows in set (0.00 sec)mysql> grant all privileges on *.* to root@'%' identified by "password";Query OK, 0 rows affected (0.00 sec)mysql> flush privileges;Query OK, 0 rows affected (0.00 sec)mysql> select host,user,password from user;+--------------+------+-------------------------------------------+| host | user | password |+--------------+------+-------------------------------------------+| localhost | root | *A731AEBFB621E354CD41BAF207D884A609E81F5E || 192.168.1.1 | root | *A731AEBFB621E354CD41BAF207D884A609E81F5E || % | root | *A731AEBFB621E354CD41BAF207D884A609E81F5E |+--------------+------+-------------------------------------------+3 rows in set (0.00 sec)

(3)mysql 时区差8个小时设置方法

       进入容器

docker exec -it mysql bash

      登录 mysql

查看系统时间和时区select now();show variables like '%time_zo

       如果 time_zone 时区是 SYSTEM 而不是东八区,也就是+8:00,那么修改配置文件

vi /etc/mysql/my.cnfdefault-time-zone = '+08:00'

       如果出现 vi command not found 则执行

apt-get update apt-get install vim

      修改完成后重启 mysql 容器,

      查看正在运行的容器信息

docker ps

      重启容器 

docker restart 容器id

总结

提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文仅仅简单介绍了pandas的使用,而pandas提供了大量能使我们快速便捷地处理数据的函数和方法。

Copyright © 2016-2020 www.365daan.com All Rights Reserved. 365答案网 版权所有 备案号:

部分内容来自互联网,版权归原作者所有,如有冒犯请联系我们,我们将在三个工作时内妥善处理。