1. 序言

将应用容器化更方便于管理,昨天辛辛苦苦安装在宿主机上的,今天狠心重置服务器,学下docker练练手。

2. Get start

2.1 安装Docker

公司的云用的是ubuntu,我自己的用的是centos,不过都差不多,在Runnoob上有详细的教程,可以在这里查看

2.2 安装mysql

在 / 目录下执行 mkdir -p /mysql/{conf.d,mysql} 可以根据喜好改名,主要是挂载一些配置文件。

执行以下命令:

docker run --name mysql \
--restart=always \
-p 3306:3306 \
-v /mysql/conf.d:/etc/mysql/conf.d \
-v /mysql/mysql:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=<你的root密码> \
mysql

如果你的镜像库中没有mysql,docker会自动下载,注意,默认下载最新版本,可以通过加 -d mysql : <版本号> 的方式,或者提前pull指定版本的数据库安装。

我直接安装了最新的版本,目前是8.0.18,但是有个问题,新版本数据库需要设置native password才可以远程登录。

接下来进入数据库,开一个用户,设置上面说到的东西吧。

docker exec -it mysql bash

mysql -p

--输入密码

create user '<想要的用户名>'@'%' identified by '<密码>';

grant all on *.* to '<上面那个用户名>'@'%';

flush privileges;

alter user '<上面那个用户名>'@'%' identified by '<密码>' password expire never;

alter user '<上面那个用户名>'@'%' identified with mysql_native_password by '<密码>';

flush privileges;

之后就可以用navicat等工具在远程登录了。

2.3 安装Nginx

安装mysql并没有耗我太多时间,但是nginx的坑可真多啊。

首先我在根目录下创建一个文件夹,用于挂在配置文件。

mkdir -p /nginx/{conf,conf.d,log,dist}

conf: 用于放主配置文件

conf.d: 用于放一些主配置文件下拆出来的东西

log: 放logs

dist: 其实一般叫做html比较好,用于存放打包的文件,叫dist可以直接拉过来不用改名了

然后在conf里写一个nginx.conf

touch nginx.conf

vim nignx.conf

写入:


user nginx;
worker_processes 1; error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid; events {
worker_connections 1024;
} http {
include /etc/nginx/mime.types;
default_type application/octet-stream; log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"'; access_log /var/log/nginx/access.log main; sendfile on;
#tcp_nopush on; keepalive_timeout 65; #gzip on; include /etc/nginx/conf.d/*.conf;
}

在conf.d中添加一个随便叫什么都可以的.conf

touch default.conf

vim default.conf

写入:

server {
listen 80;
server_name localhost; #charset koi8-r;
#access_log /var/log/nginx/host.access.log main; location / {
root /usr/share/nginx/html;
index index.html index.htm;
} #error_page 404 /404.html; # redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
try_files $uri $uri/ /index.html;
} # proxy the PHP scripts to Apache listening on 127.0.0.1:80
#
#location ~ \.php$ {
# proxy_pass http://127.0.0.1;
#} # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
#location ~ \.php$ {
# root html;
# fastcgi_pass 127.0.0.1:9000;
# fastcgi_index index.php;
# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
# include fastcgi_params;
#} # deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#
#location ~ /\.ht {
# deny all;
#}
}

写完了之后就好了,创建nginx容器。

docker run --name nginx -d -p 80:80 \
-v /nginx/log:/var/log/nginx \
-v /nginx/conf.d:/etc/nginx/conf.d \
-v /nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /nginx/dist:/usr/share/nginx/html nginx

分别把配置文件和静态文件目录挂载。

这里直接映射到了80端口,如果有冲突的话,可以改成别的。

做到这里如果一切正常,那么应该成功了。

  • 编辑,当需要在一个nginx中暴露多个端口部署多个站点时,可以-p -p一直开下去
docker run --name nginx -d -p 80:80 -p 443:443 \
-v /nginx/cert:/cert \
-v /nginx/log:/var/log/nginx \
-v /nginx/conf.d:/etc/nginx/conf.d \
-v /nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /nginx/dep:/usr/share/nginx/html nginx

坑点

  • 不知道配置文件的格式,虽然和昨天的配置差不多,但是还是希望看到新的配置文件, 解决方案:
  1. 先安装一个不设置挂载的nginx容器
  2. 使用docker cp 把这两个文件copy到宿主机上

    如果你的网速够快,可以apt-get update apt-get install vim-tiny, 然后vi打开配置文件直接复制出来(并不推荐,但是我是这么做的)
  • 刷新404

这好像是Vue项目的问题,其他不知道会不会有这种问题,因为每次刷新相当于请求那个url的文件,肯定是不存在的,也不可能拦截所有/~,解决方案也很优雅,添加 try_files $uri $uri/ /index.html; 就可以了。(上面已加)

  • 还有遇到问题的话,一定要看一下docker log。我所有都配置完成后,发现启动nginx闪退,也没有报错,看了log才知道它报了不识别erver。。。才发现少写了个s,坑啊。大家复制一定要仔细,不要漏东西。

Docker安装Mysql和Nginx的更多相关文章

  1. Docker安装mysql、nginx、redis、tomcat

    拉取mysql 5.7官方镜像 docker pull mysql:5.7 启动容器 docker run --name mysql5.7 -p 3306:3306 -e MYSQL_ROOT_PAS ...

  2. 【Linux】【自学笔记】Linux下面docker安装mysql

    写在前面: 捣腾继续,之前把一个SpringBoot的程序安装在docker上面,参考链接:https://www.cnblogs.com/aki-stones/p/2019-11-01-note.h ...

  3. docker初识-docker安装、基于docker安装mysql及tomcat、基本命令

    一.docker是什么 用go语言开发,开源的应用容器引擎,容器性能开销极低 二.整体架构图 Docker 包括三个基本概念: 镜像(Image):Docker 镜像(Image),就相当于是一个 r ...

  4. 使用Docker安装Mysql

    最近使用阿里云服务器,学习一下Docker,今天学着使用Docker安装MySQL. 首先,从阿里云的Docker Hub 上pull一个MySQL的image. [centos@loovelj~]$ ...

  5. Docker学习实践 - Docker安装MySql数据库

    Docker安装MySQL数据库 1.Ubuntu安装MySQL安装 (1)安装编译源码需要的包 sudo apt-get install make cmake gcc g++ bison libnc ...

  6. 使用docker安装mysql和redis

    本文介绍在linux下使用docker安装mysql和redis. 原文地址:代码汇个人博客 http://www.codehui.net/info/59.html 测试环境:centos7.6,do ...

  7. 解决Docker安装MySQL不区分大小写问题

    Docker安装MySQL忽略大小写问题的问题连接MySQL: 查看当前mysql的大小写敏感配置 show global variables like '%lower_case%'; +------ ...

  8. [转]Docker学习之四:使用docker安装mysql

    本文转自:https://blog.csdn.net/qq_19348391/article/details/82998391 Docker学习之一:注册Docker Hub账号 Docker学习之二 ...

  9. SpringBoot Docker Mysql安装,Docker安装Mysql

    SpringBoot Docker Mysql安装,Docker安装Mysql ================================ ©Copyright 蕃薯耀 2018年4月8日 ht ...

随机推荐

  1. 临时更换pip国内源

    源 地址 阿里云 http://mirrors.aliyun.com/pypi/simple/ 豆瓣 http://pypi.douban.com/simple/ 清华大学 https://pypi. ...

  2. vue--vue-resource实现 get, post, jsonp请求

    vue-resource 实现 get, post, jsonp请求 除了 vue-resource 之外,还可以使用 axios 的第三方包实现实现数据的请求 之前的学习中,如何发起数据请求? 常见 ...

  3. centos7基础安装

    基础: hostname xxvim /etc/hostname systemctl stop firewalld systemctl disable firewalldsetenforce 0gre ...

  4. DBGridEh列宽自动适应内容的简单方法

    ///////Begin   Source      uses          Math;            function   DBGridRecordSize(mColumn:   TCo ...

  5. tourist's modular arithmetic class

    #include <bits/stdc++.h> using namespace std; template <typename T> T inverse(T a, T m) ...

  6. Dedesql数据库类详解(二次开发必备教程)

    其实数据库类织梦之前就有一个介绍,http://help.dedecms.com/v53/archives/functions/db/,这篇文章讲解了数据库类的一些常见的使用方法,不过没有结合例子去介 ...

  7. python 写接口供外部调用

    .py: import requests import urllib2 import commands import subprocess def check(): status, msg = com ...

  8. 客户端相关知识学习(二)之h5与原生app交互的原理

    前言 现在移动端 web 应用,很多时候都需要与原生 app 进行交互.沟通(运行在 webview中),比如微信的 jssdk,通过 window.wx 对象调用一些原生 app 的功能.所以,这次 ...

  9. MySQL 主从同步架构中你不知道的“坑”(2)

    指定同步库情况 1.binlog_format= ROW模式‍ mysql> use testdb; Database changed mysql> show tables; +----- ...

  10. 07 MySQL之索引原理

    一.介绍 为什么有索引:使用索引可快速访问数据库表中的特定信息.索引是对数据库表中一列或多列的值进行排序的一种结构. 作用: 1.        快速查询数据 2.        保证数据的唯一性 3 ...