配置docker环境

零、安装Docker

安装环境:Ubuntu 16.04.2 LTS
 

 

#卸载旧版本
apt-get remove docker \
               docker-engine \
               docker.io
#开始安装
apt-get update

#添加使用 HTTPS 传输的软件包以及 CA 证书
apt-get install \
    apt-transport-https \
    ca-certificates \
    curl \
    software-properties-common

#确认所下载软件包的合法性,需要添加软件源的 GPG 密钥
curl -fsSL https://mirrors.ustc.edu.cn/docker-ce/linux/ubuntu/gpg | sudo apt-key add -

# 向 source.list 中添加 Docker 软件源
sudo add-apt-repository \
    "deb [arch=amd64] https://mirrors.ustc.edu.cn/docker-ce/linux/ubuntu \
    $(lsb_release -cs) \
    stable"

apt-get update
#安装DockerCE
apt-get install docker-ce

#如果提示没有安装docker.io就执行下面的命令
apt-get install docker.io

#启动 Docker CE
systemctl enable docker
systemctl start docker

一、 普通方法创建容器

  1. 用Docker的ubuntu镜像创建一个容器

 

docker run -d --name=testUbuntu ubuntu tail -f /dev/null
  1. 进入容器

 

docker exec -it testUbuntu bash
  1. 更新apt-get

 

apt-get update
  1. 安装需要的东西

 

#安装常用工具
apt-get install -y vim
apt-get install -y tree
apt-get install -y net-tools
#安装nginx
apt-get install -y nginx
#安装Python2
apt-get install -y python2.7
#安装Python3
apt-get install -y python3.7
#安装pip3
apt-get install python3-pip
#安装pip
apt-get install -y python-pip python-dev build-essential
#安装supervisor
apt-get install -y supervisor

#安装mysql
apt-get install -y mysql-server
apt-get install -y mysql-client
apt-get install -y libmysqlclient-dev
#检测mysql安装是否成功
netstat -tap | grep mysql
  1. 搭建项目环境

 

# 导出项目所用的模块
pip freeze >requirements.txt

# 安装导出项目所用的模块
pip install -r requirements.txt

二、 Dockerfile方法创建容器

也可将上面的命令做成Dockerfile,内容如下:

 

FROM ubuntu:latest

#注意,换行用TAB

RUN apt-get update \
    && apt-get install -y vim \
    && apt-get install -y tree \
    && apt-get install -y net-tools \
    && apt-get install -y git \
    && apt-get install -y nginx \
    && apt-get install -y redis-server \
    && apt-get install -y python2.7 \
    && apt-get install -y python3.7 \
    && apt-get install -y python3-pip \
    && apt-get install -y python-pip python-dev build-essential \
    && apt-get install -y mysql-server \
    && apt install -y mysql-client \
    && apt install -y libmysqlclient-dev

然后执行

 

docker build -t NAME:TAG .
#如:docker build -t test:v1 . 是test镜像,v1的tag
#注意!
#1. 先执行docker login
#2. 执行build命令时,要在一个空文件夹下(如果不是空文件夹要添加.dockerignore文件)
#3. 要在有Dockerfile文件下的目录执行build命令

用了一个RUN命令执行,是为了节省时间、减少臃肿。


解决问题

ubuntu中mysql启动报错
No directory, logging in with HOME=/
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)

 

#第一步
usermod -d /var/lib/mysql/ mysql
#第二步
ln -s /var/lib/mysql/mysql.sock /tmp/mysql.sock
#第三步
chown -R mysql:mysql /var/lib/mysql
#之后重启mysql即可
service mysql stop
service mysql start

安装完成后,是不需要密码登录的。设置密码操作如下 (命令来源于这里)

 

#登录mysql
root@fe3a9125ce8b:/# mysql
#mysql下执行如下命令
mysql> use mysql
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> update user set authentication_string=PASSWORD("你的密码") where user='root';
Query OK, 1 row affected, 1 warning (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 1

mysql> update user set plugin="mysql_native_password";
Query OK, 1 row affected (0.00 sec)
Rows matched: 4  Changed: 1  Warnings: 0

mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

mysql> quit
Bye

#重启mysql  
root@fe3a9125ce8b:/# service mysql restart;
 * Stopping MySQL database server mysqld                                                                                                          [ OK ] 
 * Starting MySQL database server mysqld                                                                                                                 No directory, logging in with HOME=/
                                         
#用密码登录mysql
mysql -u root -p 密码;


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值