centos 7.2 64位 docker安装lamp环境
1. 删除docker可能有的早期版本
yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
2. 安装docker需要的一些依赖
yum install -y yum-utils \
device-mapper-persistent-data \
lvm2
3. 配置docker的repo以便yum install时能够使用到最新的docker版本image
yum-config-manager \
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo
4. 安装docker-ce及cli
yum install docker-ce docker-ce-cli containerd.io
5. 立即启动docker engine并设置开机启动
systemctl start docker
systemctl enable docker
systemctl list-unit-files | grep enabled 检查确认是否已经开机启动
6. 试运行docker container
docker run hello-world
结果出错,google后发现是kernel不匹配,因为centos7.2的kernel太旧,必须更新kernel
下面将记录如何将centos7.2升级kernel到5.0,以下链接可以供参考:
https://www.tecmint.com/install-upgrade-kernel-version-in-centos-7/
https://www.jianshu.com/p/1261ed6f8399
7.配置repo,并且安装最新的linux kernel(5.0)
rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org
rpm -Uvh http://www.elrepo.org/elrepo-release-7.0-3.el7.elrepo.noarch.rpm
yum --enablerepo=elrepo-kernel install kernel-ml
8. 将5.0的kernel在centos7.2中配置为开机默认项
/etc/default/grub 中增加一个GRUB_DEFAULT=0 这样就选择最新安装的那个kernel了
grub2-mkconfig -o /boot/grub2/grub.cfg 重新生成kernel配置信息,以便自动应用新安装的kernel
9. 重新启动
10. 如果有必要可以创建一个docker group,并将对应用户名加到这个group中,避免使用root直接操作,提高安全性
groupadd docker
11. 镜像加速:
在/etc/docker/daemon.json文件中添加以下内容,
{
"registry-mirrors": ["https://etomhx9s.mirror.aliyuncs.com"]
}
并执行:
sudo systemctl daemon-reload
sudo systemctl restart docker
之后所有对docker官方的镜像都会自动加速使用阿里云的mirror
12. centos安装docker-compose
curl -L "https://github.com/docker/compose/releases/download/1.23.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose
13. 安装command-line completion以便使用tab键快速列出可选子命令
请参考页面: https://docs.docker.com/compose/completion/
curl -L https://raw.githubusercontent.com/docker/compose/1.23.2/contrib/completion/bash/docker-compose -o /etc/bash_completion.d/docker-compose
//// trouble shooting:
curl https://raw.githubusercontent.com/docker/docker/master/contrib/check-config.sh > check-config.sh
bash ./check-config.sh
准备工作已经做完,下面需要安裝nginx+php-fpm(7.1)+mysql(5.6.35)+redis的容器了.
思路是:通过docker-compose方式来编排微服务,分别切分为nginx web服务器,nginx使用官方镜像;upstream php-fpm应用服务,php-fpm则基于官方7.1的镜像添加一些扩展安装以及composer安装,
注意php-fpm7.2以上版本往往会出现以下错误"Parameter must be an array or an object that implements Countable"
mysql和redis也直接使用官方镜像起一个微服务即可。其中mysql使用一个volume直接应用已经存在的数据库文件,后续可以考虑使用一个数据卷容器来服务数据
由于众所周知的伟大的墙,给我们苦逼的程序猿带来了太多的麻烦,好在docker公司提供的play-with-docker可以免费提供4G内存的云主机足够我们使用。我们直接在该云主机上使用docker-compose build命令做镜像构建,随后push到docker hub上。最后在国内的主机上docker pull下来镜像并使用docker-compose up -d nginx一下子就把所有服务拉起了!
14. 将我们的docker-compose up -d xxx作为开机启动
a)在/etc/systemd/system目录中创建一个myapp.service文本文件
[Unit]
Description=myappservice
After=docker.service#注意本服务依赖于docker service,而dockerservice又require docker.socket 必须在docker engine起来之后才能执行,docker启动比较慢,需要2分钟左右
[Service]
# see man systemd.service
Type=oneshot
WorkingDirectory=/yourworkingdirectory
ExecStart=/yourworkingdirectory/start-all.sh
RemainAfterExit=true
ExecStop=/yourworkingdirectory/stop-all.sh
StandardOutput=journal
[Install]
WantedBy=multi-user.target
b)在/yourworkingdirectory中分别创建start-all和stop-all.sh脚本
#!/bin/bash
# This is the stop script
docker-compose up -d xx
#!/bin/bash
# This is the stop script
docker-compose stop
c)将启动和停止脚本赋予执行权限: chmod u+x start-all.sh
d)# systemctl enable yourservice
Created symlink from /etc/systemd/system/multi-user.target.wants/yourservice.service to /etc/systemd/system/yourserivce.service.
搞定!
optional:
你可能希望起一个mysqladmin方便你图形化管理数据库
docker run --name myadmin -d --link dockerdeployconf_mysql_1:mysql --net dockerdeployconf_default -e PMA_HOST=mysql -p : phpmyadmin/phpmyadmin
docker-compose.yml
version: ''
services:
myapp:
build:
context: /pathtoconfig
dockerfile: Dockerfile-phpfpm
image: xx/myimage:7.1
depends_on:
- mysql
- redis
volumes:
- /pathtophpapp/:/application mysql:
image: mysql:5.6
environment:
- MYSQL_ROOT_PASSWORD=yourrootpassword
- MYSQL_DATABASE=yourdatabase
volumes:
- /pathtodatafile/:/var/lib/mysql nginx:
image: nginx
ports:
- "80:8000"
volumes:
- /pathtoconfig/nginx.conf:/etc/nginx/conf.d/default.conf
- /pathtophpapp/:/application
depends_on:
- myapp
redis:
image: redis
ports:
- "6379:6379"
dockerfile-phpfpm
FROM php:7.1-fpm
LABEL maintainer="zhang@xx.com" # Installing dependencies
RUN apt-get update && apt-get install -y \
build-essential \
mysql-client \
libpng-dev \
libjpeg62-turbo-dev \
libfreetype6-dev \
libzip-dev \
locales \
zip \
jpegoptim optipng pngquant gifsicle # Clear cache
RUN apt-get clean && rm -rf /var/lib/apt/lists/* # Installing extensions
RUN docker-php-ext-install pdo_mysql mbstring zip exif pcntl bcmath opcache
RUN docker-php-ext-configure gd --with-gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/ --with-png-dir=/usr/include/
RUN docker-php-ext-install gd # Installing composer
RUN curl -sS https://getcomposer.org/installer | php -- --install-dir=/usr/local/bin --filename=composer # Setting locales
RUN echo zh_CN.UTF-8 UTF-8 > /etc/locale.gen && locale-gen # Changing Workdir
WORKDIR /application
nginx.conf
server {
listen ;
index index.php index.html index.htm;
root /application/public; # default Laravel's entry point for all requests
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;
location / {
# try to serve file directly, fallback to index.php
try_files $uri /index.php?$args;
}
location ~ \.php$ {
fastcgi_index index.php;
fastcgi_pass myapp:; # address of a fastCGI server
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param PATH_INFO $fastcgi_https://github.com/rlerdorf/php7dev/issues/48_info;
include fastcgi_params;
}
}
其中需要另外注意的一点是:
php-fpm的log搜集问题:
catch_workers_output = yes https://github.com/rlerdorf/php7dev/issues/48
https://stackoverflow.com/questions/8677493/php-fpm-doesnt-write-to-error-log
centos 7.2 64位 docker安装lamp环境的更多相关文章
- 阿里云服务器 CentOS 7.5 64位 docker安装redis集群
网上有很多教程可以参考,但是遇到坑了...... 最后参考这个教程成功了.https://www.cnblogs.com/hbbbs/articles/10028771.html 安装docker 参 ...
- CentOS 6.5 64位下安装Redis3.0.2的具体流程
系统环境:CentOS 6.5 64位 安装方式:编译安装 防火墙:开启 Redis版本:Redis 3.0.2 一.环境准备 1.安装 gcc gcc-c++ [root@iZ94ebgv853Z ...
- Linux CentOS 6.5 64位 静默安装Oracle11g 云主机
本例: 通过SSH远程连接云主机,上传oracle11g安装包,在centos6.5上无图形化界面静默安装oracle11g. 涉及工具及环境: 1.本地环境windows7+ssh远程连接工具xSh ...
- docker 安装LAMP环境
LAMP:Linux.Apache.MySQL.PHP docker hub 上会有配好的LAMP环境docker,部署到本地并运行起来 sudo docker pull linode/lamp 然后 ...
- CentOS 6.5 64位下安装MySQL 5.7.11
昨天花了一下午在CentOS6.5 上安装了MySQL,版本为5.7.11,下面介绍一下我安装时候出现的问题 以及解决方法,供大家参考. 1/清除残留 rpm -qa | grep mysql // ...
- 在 CentOS 7.5 64位上使用 yum 安装 MySQL 8.0
前段时间在 CentOS 7.5 64位上安装 MySQL 8.0.查了些资料,在这里记录一下详细的安装和设置步骤. 一.安装 使用yum安装MySQL之前需要先下载对应的.rpm文件,下载方法: 去 ...
- 阿里云服务器CentOS 5.7(64位)安装配置LAMP服务器(Apache+PHP5+MySQL)
一.快速安装Apache+PHP5+MySql ----------------------------------------------------- 补充:由于163的yum源上只有php5.1 ...
- CentOS 6.3 64位下MySQL5.1.54源码安装配置详解
安装环境:CentOS 6.3 64位 一:先安装依赖包(不然配置的时候会报错的!) yum -y install ncurses* libtermcap* 新建mysql用户 [root@clien ...
- 使用centos 5.x 64位系统安装astgo 2014 v7.3教程(含全套安装文件)
版本特色: 全自动安装 安装过程中不用频繁输入yes或回车 自带完整号码归属地数据库 自带触屏版WAP ·首先确定你需要使用astgo 2014 7.0还是7.3: astgo 2014 v 7.0 ...
随机推荐
- Spring MVC & Boot & Cloud 技术教程汇总(长期更新)
昨天我们发布了Java成神之路上的知识汇总,今天继续. Java成神之路技术整理(长期更新) 以下是Java技术栈微信公众号发布的关于 Spring/ Spring MVC/ Spring Boot/ ...
- Python常用模块——json & pickle
序列化模块 1.什么是序列化-------将原本的字典,列表等对象转换成一个字符串的过程就叫做序列化 2.序列化的目的 1.以某种存储形式使自定义对象持久化 2.将对象从一个地方传递到另一个地方 3. ...
- JStorm-介绍
1.概述 JStorm 是一个类似于 Hadoop 的MapReduce的计算系统,它是由Alibaba开源的实时计算模型,它使用Java重写了原生的Storm模型(Clojure和Java混合编写的 ...
- 解决Android Studio 3.x版本的安装时没有SDK,运行时出现SDK tools错误
好久没更新了,最近手机上的闹钟APP没一个好用的,所以想自己写个. 那Android开发环境搭起来,注意先装好jdk. 1.安装Android Studio google的Android开发网站已经有 ...
- SpringBoot+Mybatis+Pagehelper分页
1.pom.xml <!-- mybatis分页插件 --> <dependency> <groupId>com.github.pagehelper</gro ...
- Docker数据卷容器备份、恢复
1.备份数据卷容器 使用数据卷来备份数据,通过指定本地的一个文件路径,对应到容器中的路径,运行tar命令将重要的文件打包备份. $ cd /home/xm6f/dev $ docker run --v ...
- 理解交叉熵(cross_entropy)作为损失函数在神经网络中的作用
交叉熵的作用 通过神经网络解决多分类问题时,最常用的一种方式就是在最后一层设置n个输出节点,无论在浅层神经网络还是在CNN中都是如此,比如,在AlexNet中最后的输出层有1000个节点: 而即便是R ...
- SaltStack快速入门-配置管理
1:定义远程配置时描述位置,salt配置用的是一种yaml的描述语法,saltstack也是可以分环境的,比如测试环境.生产环境,默认是base,base也是必须存在的,修改内容如下: file_ro ...
- SpringBoot之Mybatis操作中使用Redis做缓存
上一博客学习了SpringBoot集成Redis,今天这篇博客学习下Mybatis操作中使用Redis做缓存.这里其实主要学习几个注解:@CachePut.@Cacheable.@CacheEvict ...
- js------保留指定位数小数
// tofix.js文件// params// val: 要处理的数据,Number | String// len: 保留小数位数,位数不足时,以0填充// side: 1|-1 对应 入|舍exp ...