1 Docker Compose

  • Compose是什么
  • Linux安装Compose
  • Compose常用命令选项
  • YAML文件格式及编写注意事项
  • Compose配置文件常用参数
  • Compose应用实战
    • 一键部署LNMP网站平台
    • —键部署Nginx反向代理Tomcat集群
    • —键部署多节点爬虫程序

1.1 Docker Compose 是什么

Compose是一个定义和管理多容器的工具,也是一种容器编排工具,前身是Pig,使用Python语言编写。使用Compose配置文件描述多个容器应用的架构,比如使用什么镜像、数据卷、网络、映射端口等;然后一条命令管理所有服务,比如启动、停止、重启等。

Docker 建议我们每一个容器中只运行一个服务,因为docker容器本身占用资源极少,所以最好是将服务单独的分割开来,但是这样我们又面临了一个问题?

如果我们需要同时部署好多个服务,难道要每个服务单独写Dockerfile,然后再构建镜像,镜像容器,这样会很累,所以docker官方给我们提供了 docker-compose 多服务部署工具。

例如要实现一个Web微服务项目,除了Web服务容器本身,往往还需要再加上后端的数据库mysql服务容器,redis服务器,注册中心eureka,甚至还包括负载均衡容器等等。。。

Compose 允许用户通过一个单独的 docker-compose.yml 模板文件(YAML格式)来定义一组相关联的应用容器为一个项目(project)

可以很容易的用一个配置文件定义一个/一组多容器的应用,然后使用一条指令安装这个应用的所有依赖,完成构建。Docker-Compose解决了容器与容器之间如何管理编排的问题。

:::color1 Docker compose 是单机(本机)的多容器管理技术

K8s 是跨主机的集群部署工具

:::

1.2 Linux 安装 Compose

  1. 下载二进制文件
  1. curl -L https://github.com/docker/compose/releases/download/$dockerComposeVersion/docker-compose-`uname -s`-`uname -m` \
  2. -o /usr/local/bin/docker-compose

例如:

  1. curl -L https://github.com/docker/compose/releases/download/1.14.O/docker-compose-`uname -s`-`uname -m` \
  2. -o /usr/local/bin/docker-compose
  1. 对二进制文件添加可执行权限
  1. chmod +x /usr/local/bin/docker-compose
  1. 测试安装
  1. docker-compose --version

也可以使用pip工具安装:pip install docker-compose

访问GitHub受限,则可以使用 DaoCloud 的Docker Compose镜像站,范例:

  1. # 高速安装Docker Compose
  2. curl -L https://get.daocloud.io/docker/compose/releases/download/v2.13.0/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
  3. chmod +x /usr/local/bin/docker-compose
  4. # 管理员可以通过修改URL中的版本,可以自定义管理员的需要的版本。

Docker Compose 的简单使用

docker-compose.yml

  1. version: "3"
  2. services:
  3. web:
  4. build: .
  5. ports:
  6. - "8888:80"

Dockerfile

  1. FROM centos:6
  2. MAINTAINER <zhongzhiwei zhongzhiwei@kubesphere.io>
  3. RUN curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-vault-6.10.repo
  4. RUN yum install -y httpd php php-gd php-mysql
  5. RUN echo "<?php phpinfo()?>" > /var/www/html/index.php
  6. CMD ["/usr/sbin/httpd", "-D", "FOREGROUND"]
  7. EXPOSE 80

运行 Docker-Compose 项目

  1. $ docker-compose up -d
  2. # 构建新的镜像
  3. $ docker images
  4. REPOSITORY TAG IMAGE ID CREATED SIZE
  5. docker-compose-php-web latest 364918cfae39 4 minutes ago 373MB
  6. # 查看docker-compose的进程
  7. $ docker-compose ps
  8. NAME COMMAND SERVICE STATUS PORTS
  9. docker-compose-php-web-1 "/usr/sbin/httpd -D …" web running 0.0.0.0:8888->80/tcp, :::8888->80/tcp
  10. # 使用浏览器访问主机的8888端口或者使用curl进行访问
  11. $ curl -XGET http://127.0.0.1:8888

1.3 YAML文件格式及编写注意事项

YAML是一种标记语言很直观的数据序列化格式,可读性高。类似于XML数据描述语言,语法比KML简单的很多。

YAML数据结构通过缩进”Tab”来表示,连续的项目通过减号”-“来表示,键值对用冒号分隔,数组用中括号括起来,hash用花括号括起来。

YAML文件格式注意事项:

  1. 不支持制表符tab键缩进,需要使用空格缩进
  2. 通常开头缩进2个空格
  3. 字符后缩进1个空格,如冒号、逗号、横杆
  4. 用”#”号注释
  5. 如果包含特殊字符用单引号引起来
  6. 布尔值(true、false、yes、no、on、off)必须用引号括起来,这样分析器会将他们解释为字符串。

1.4 Docker Compose 常用的选项和命令

01 Docker 进阶 %26 Kubernetes 入门 - 图1

  1. Usage: docker compose [OPTIONS] COMMAND
  2. 选项:
  3. -f 指定Compose配置文件,默认docker-compose.yml
  4. -p 指定项目名称,默认目录名
  5. --verbose显示更多的输出
命令 描述
build
Usage: docker compose build [OPTIONS] [SERVICE…]
—no-cache 不使用缓存构建镜像
—build-arg stringArray 设置构建时变量
重新构建服务
config
Usage: docker compose convert [OPTIONS] [SERVICE…]
-q, —quiet 只验证不打印
—services 只打印服务名称,每行一个
—volumes 打印数据卷名称,每行一个
验证和查看Compose文件
exec
Usage: docker compose exec [OPTIONS] SERVICE COMMAND [ARGS…]
-d, —detach 在后台运行命令
—privileged 给这个进程赋予特权权限
-u, —user string 作为该用户运行该命令
-T, —no-TTY docker compose exec 禁用分配伪终端,默认分配一个终端
—index int 多个容器时的索引数字,默认为1
在运行的容器里执行命令
port
Usage: docker compose port [OPTIONS] SERVICE PRIVATE_PORT
—index int 多个容器时的索引数字,默认为1
—protocol string TCP或者UDP,默认TCP
打印绑定的开放端口
ps
Usage: docker compose ps [OPTIONS] [SERVICE…]
-q, —quiet 只打印容器ID
列出容器
rm
Usage: docker compose rm [OPTIONS] [SERVICE…]
-f, —force Don’t ask to confirm removal 强制删除
-s, —stop Stop the containers, if required, before removing 删除容器时如果需要先停止容器
-v, —volumes Remove any anonymous volumes attached to containers 删除与容器相关的任何匿名卷
删除停止的服务容器
scale
Usage: scale [options] [SERVICE-NUM..]
指定一个服务启动的容器数量
up
Usage: docker compose up [OPTIONS] [SERVICE…]
-d, —detach 在后台运行容器
—no-deps 不启动连接服务
—no-recreate 如果容器存在,不重连它们
—no-build 不构建镜像,即使它丢失
—build 启动容器下构建镜像( 默认 )
—scale SERVICE=NUM 指定一个服务( 容器 )的启动数量
创建和启动容器
stop
Usage: docker compose stop [OPTIONS] [SERVICE…]
停止服务
start
Usage: docker compose start [SERVICE…]
restart
Usage: docker compose restart [OPTIONS] [SERVICE…]
重启服务
top
Usage: docker compose top [SERVICES…]
显示容器运行的进程
logs
Usage: docker compose logs [OPTIONS] [SERVICE…]
-f, —follow 实时输出日志
-t, —timestamps 显示时间戳
—tail string =”all” 从日志末尾显示行数
显示容器日志的输出
down 停止容器和删除容器、网络、数据卷和镜像

1.5 Compose配置文件常用参数

Reference:https://docs.docker.com/compose/compose-file/#privileged

描述 描述
build 构建镜像 external_links 连接Compose之外的容器
dockerfile 上下文路径指定Dockefile文件名 extra_hosts 添加主机名映射,与—add-host相同
image 来自镜像 logging 记录该服务的日志。与—log-driver相同
args 构建参数。在Doekerfile中指定的参数 network_mode 网络模式,与—net相同
command 覆盖默认命令 networks
aliases
ipv4_address, ipv6_address
要加入的网络。
在加入网络时为该服务指定容器的静态IP地址
container_name 自定义容器名称:如果自定文名称,则无法将服务scale 到 1 容器之外 pid 将PID模式设置主机PID模式,与宿主机共享PID地址空间。pid:”host”
deploy 指定与部署和运行相关的配置。限版本3 ports 暴露端口,与-p相同,但端口不低于60
depends_on 服务之间的依赖,控制服务启动版序。正常是按顺序启动服务 sysctls 再容器内设置内核参数,可以是数组或字典
dns 自定义DNS服务器,可以是单个值或列表 ulimits 覆盖容器的默认ulimits
entrypoint 覆盖entrypoint volumes 挂载一个目录或一个已存在的数据卷容器到容器
env_file 从文件添加环境变里,可以是单个值或列表 restart 默认 no,可设置 always on-failure l unless-stopped
environment 添加环境变里,可以是数组或字典。布尔值用引号括起来 hostname 主机名
expose 声明容器服务瑞口 working_dir 工作目录
links 连接到另一个容器 privilege 将服务容器配置为使用提升的权限运行。支持和实际影响是特定于平台的。

1.6 Docker Compose 应用实战

  • 一键部署 LNMP 网站平台
  • 一键部署 Nginx 反向代理 Tomcat 集群
  • 一键部署多节点爬虫程序

1.6.1 一键部署 LNMP 网站平台

  • Nginx 部署

Nginx Dockerfile

  1. FROM centos:6
  2. MAINTAINER <zhongzhiwei zhongzhiwei@kubesphere.io>
  3. # 获取最新Yum源信息 & 下载相应软件
  4. RUN curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-vault-6.10.repo && \
  5. yum install -y gcc gcc-c++ make openssh-server pcre-devel openssl zlib-devel
  6. ADD http://nginx.org/download/nginx-1.12.2.tar.gz /tmp
  7. RUN cd /tmp && \
  8. tar -zxvf nginx-1.12.2.tar.gz && \
  9. cd nginx-1.12.2 && \
  10. ./configure --prefix=/usr/local/nginx && \
  11. make -j 4 && make install
  12. RUN useradd nginx
  13. # nginx.conf 配置文件内容
  14. # user nginx;
  15. # worker_processes auto;
  16. # error_log /var/log/nginx/error.log;
  17. # pid /run/nginx.pid;
  18. #
  19. # events {
  20. # worker_connections 1024;
  21. # }
  22. #
  23. # http {
  24. # log_format main '$remote_addr - $remote_user [$time_local] "$request" '
  25. # '$status $body_bytes_sent "$http_referer" '
  26. # '"$http_user_agent" "$http_x_forwarded_for"';
  27. #
  28. # access_log logs/access.log main;
  29. #
  30. # sendfile on;
  31. # tcp_nopush on;
  32. # tcp_nodelay on;
  33. # keepalive_timeout 65;
  34. # types_hash_max_size 4096;
  35. #
  36. # include /etc/nginx/conf.d/*.conf;
  37. #
  38. # server {
  39. # listen 80;
  40. # listen [::]:80;
  41. # server_name localhost;
  42. # root html;
  43. #
  44. # index index.html index.php;
  45. # location ~ \.php$ {
  46. # root html;
  47. #
  48. # fastcgi_pass php-cgi:9000;
  49. # fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
  50. # include fastcgi_params;
  51. # }
  52. # }
  53. # }
  54. COPY nginx.conf /usr/local/nginx/conf
  55. # 声明容器服务端口
  56. EXPOSE 80
  57. # 启动Nginx服务
  58. CMD ["/usr/local/nginx/sbin/nginx", "-g", "daemon off;"]

Nginx 配置文件

  1. user nginx;
  2. worker_processes auto;
  3. error_log logs/error.log info;
  4. pid logs/nginx.pid;
  5. events {
  6. worker_connections 1024;
  7. }
  8. http {
  9. log_format main '$remote_addr - $remote_user [$time_local] "$request" '
  10. '$status $body_bytes_sent "$http_referer" '
  11. '"$http_user_agent" "$http_x_forwarded_for"';
  12. access_log logs/access.log main;
  13. sendfile on;
  14. tcp_nopush on;
  15. tcp_nodelay on;
  16. keepalive_timeout 65;
  17. types_hash_max_size 4096;
  18. # include /etc/nginx/conf.d/*.conf;
  19. server {
  20. listen 80;
  21. listen [::]:80;
  22. server_name localhost;
  23. root html;
  24. index index.html index.php;
  25. location ~ \.php$ {
  26. root html;
  27. fastcgi_pass php-cgi:9000;
  28. fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
  29. include fastcgi_params;
  30. }
  31. }
  32. }
  • MySQL 部署

MySQL 配置文件

  1. mkdir conf && cd conf && vim my.cnf
  2. [mysqld]
  3. user = mysql
  4. port = 3306
  5. datadir = /var/lib/mysql
  6. socket = /var/lib/mysql/mysql.sock
  7. pid-file = /var/run/mysql/mysql.pid
  8. log_error = /var/log/mysql/error.log
  9. character_set_server = utf8mb4
  10. character_set_client = utf8mb4
  11. max_connections = 3600
  • php 部署

php Dockerfile

  1. FROM centos:6
  2. MAINTAINER <zhongzhiwei zhongzhiwei@kubesphere.io>
  3. # 获取最新Yum源信息 & 下载相应软件
  4. RUN curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-vault-6.10.repo && \
  5. yum install -y gcc gcc-c++ gd-devel libxml2-devel libcurl-devel libjpeg-devel libpng-devel openssl-devel
  6. ADD http://docs.php.net/distributions/php-5.6.31.tar.gz /tmp/
  7. RUN cd /tmp/php-5.6.31 && \
  8. ./configure --prefix=/usr/local/php \
  9. --with-config-file-path=/usr/local/php/etc \
  10. --with-mysql --with-mysqli \
  11. --with-openssl --with-ziib --with-curl --with-gd \
  12. --with-jpeg-dir --with-png-dir --with-iconv \
  13. --enable-fpm --enable-zip --enable-mbstring && \
  14. make -j 4 && \
  15. make install && \
  16. cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf && \
  17. sed -i "s/127.0.0.1/0.0.0.0/" /usr/local/php/etc/php-fpm.conf && \
  18. cp ./sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm && \
  19. chmod +x /etc/init.d/php-fpm
  20. # rm -rf /tmp /php-5.6.31
  21. COPY php.ini /usr/local/php/etc
  22. CMD /etc/init.d/php-fpm start && tail -F /var/log/messages
  23. # 声明容器服务端口
  24. EXPOSE 9000

php 配置文件[ 设置时区为上海时区 ]

  1. [PHP]
  2. ;;;;;;;;;;;;;;;;;;;
  3. ; About php.ini ;
  4. ;;;;;;;;;;;;;;;;;;;
  5. ; PHP's initialization file, generally called php.ini, is responsible for
  6. ; configuring many of the aspects of PHP's behavior.
  7. ; PHP attempts to find and load this configuration from a number of locations.
  8. ; The following is a summary of its search order:
  9. ; 1. SAPI module specific location.
  10. ; 2. The PHPRC environment variable. (As of PHP 5.2.0)
  11. ; 3. A number of predefined registry keys on Windows (As of PHP 5.2.0)
  12. ; 4. Current working directory (except CLI)
  13. ; 5. The web server's directory (for SAPI modules), or directory of PHP
  14. ; (otherwise in Windows)
  15. ; 6. The directory from the --with-config-file-path compile time option, or the
  16. ; Windows directory (C:\windows or C:\winnt)
  17. ; See the PHP docs for more specific information.
  18. ; http://php.net/configuration.file
  19. ; The syntax of the file is extremely simple. Whitespace and lines
  20. ; beginning with a semicolon are silently ignored (as you probably guessed).
  21. ; Section headers (e.g. [Foo]) are also silently ignored, even though
  22. ; they might mean something in the future.
  23. ; Directives following the section heading [PATH=/www/mysite] only
  24. ; apply to PHP files in the /www/mysite directory. Directives
  25. ; following the section heading [HOST=www.example.com] only apply to
  26. ; PHP files served from www.example.com. Directives set in these
  27. ; special sections cannot be overridden by user-defined INI files or
  28. ; at runtime. Currently, [PATH=] and [HOST=] sections only work under
  29. ; CGI/FastCGI.
  30. ; http://php.net/ini.sections
  31. ; Directives are specified using the following syntax:
  32. ; directive = value
  33. ; Directive names are *case sensitive* - foo=bar is different from FOO=bar.
  34. ; Directives are variables used to configure PHP or PHP extensions.
  35. ; There is no name validation. If PHP can't find an expected
  36. ; directive because it is not set or is mistyped, a default value will be used.
  37. ; The value can be a string, a number, a PHP constant (e.g. E_ALL or M_PI), one
  38. ; of the INI constants (On, Off, True, False, Yes, No and None) or an expression
  39. ; (e.g. E_ALL & ~E_NOTICE), a quoted string ("bar"), or a reference to a
  40. ; previously set variable or directive (e.g. ${foo})
  41. ; Expressions in the INI file are limited to bitwise operators and parentheses:
  42. ; | bitwise OR
  43. ; ^ bitwise XOR
  44. ; & bitwise AND
  45. ; ~ bitwise NOT
  46. ; ! boolean NOT
  47. ; Boolean flags can be turned on using the values 1, On, True or Yes.
  48. ; They can be turned off using the values 0, Off, False or No.
  49. ; An empty string can be denoted by simply not writing anything after the equal
  50. ; sign, or by using the None keyword:
  51. ; foo = ; sets foo to an empty string
  52. ; foo = None ; sets foo to an empty string
  53. ; foo = "None" ; sets foo to the string 'None'
  54. ; If you use constants in your value, and these constants belong to a
  55. ; dynamically loaded extension (either a PHP extension or a Zend extension),
  56. ; you may only use these constants *after* the line that loads the extension.
  57. ;;;;;;;;;;;;;;;;;;;
  58. ; About this file ;
  59. ;;;;;;;;;;;;;;;;;;;
  60. ; PHP comes packaged with two INI files. One that is recommended to be used
  61. ; in production environments and one that is recommended to be used in
  62. ; development environments.
  63. ; php.ini-production contains settings which hold security, performance and
  64. ; best practices at its core. But please be aware, these settings may break
  65. ; compatibility with older or less security conscience applications. We
  66. ; recommending using the production ini in production and testing environments.
  67. ; php.ini-development is very similar to its production variant, except it is
  68. ; much more verbose when it comes to errors. We recommend using the
  69. ; development version only in development environments, as errors shown to
  70. ; application users can inadvertently leak otherwise secure information.
  71. ; This is php.ini-development INI file.
  72. ;;;;;;;;;;;;;;;;;;;
  73. ; Quick Reference ;
  74. ;;;;;;;;;;;;;;;;;;;
  75. ; The following are all the settings which are different in either the production
  76. ; or development versions of the INIs with respect to PHP's default behavior.
  77. ; Please see the actual settings later in the document for more details as to why
  78. ; we recommend these changes in PHP's behavior.
  79. ; display_errors
  80. ; Default Value: On
  81. ; Development Value: On
  82. ; Production Value: Off
  83. ; display_startup_errors
  84. ; Default Value: Off
  85. ; Development Value: On
  86. ; Production Value: Off
  87. ; error_reporting
  88. ; Default Value: E_ALL & ~E_NOTICE & ~E_STRICT & ~E_DEPRECATED
  89. ; Development Value: E_ALL
  90. ; Production Value: E_ALL & ~E_DEPRECATED & ~E_STRICT
  91. ; html_errors
  92. ; Default Value: On
  93. ; Development Value: On
  94. ; Production value: On
  95. ; log_errors
  96. ; Default Value: Off
  97. ; Development Value: On
  98. ; Production Value: On
  99. ; max_input_time
  100. ; Default Value: -1 (Unlimited)
  101. ; Development Value: 60 (60 seconds)
  102. ; Production Value: 60 (60 seconds)
  103. ; output_buffering
  104. ; Default Value: Off
  105. ; Development Value: 4096
  106. ; Production Value: 4096
  107. ; register_argc_argv
  108. ; Default Value: On
  109. ; Development Value: Off
  110. ; Production Value: Off
  111. ; request_order
  112. ; Default Value: None
  113. ; Development Value: "GP"
  114. ; Production Value: "GP"
  115. ; session.gc_divisor
  116. ; Default Value: 100
  117. ; Development Value: 1000
  118. ; Production Value: 1000
  119. ; session.hash_bits_per_character
  120. ; Default Value: 4
  121. ; Development Value: 5
  122. ; Production Value: 5
  123. ; short_open_tag
  124. ; Default Value: On
  125. ; Development Value: Off
  126. ; Production Value: Off
  127. ; track_errors
  128. ; Default Value: Off
  129. ; Development Value: On
  130. ; Production Value: Off
  131. ; url_rewriter.tags
  132. ; Default Value: "a=href,area=href,frame=src,form=,fieldset="
  133. ; Development Value: "a=href,area=href,frame=src,input=src,form=fakeentry"
  134. ; Production Value: "a=href,area=href,frame=src,input=src,form=fakeentry"
  135. ; variables_order
  136. ; Default Value: "EGPCS"
  137. ; Development Value: "GPCS"
  138. ; Production Value: "GPCS"
  139. ;;;;;;;;;;;;;;;;;;;;
  140. ; php.ini Options ;
  141. ;;;;;;;;;;;;;;;;;;;;
  142. ; Name for user-defined php.ini (.htaccess) files. Default is ".user.ini"
  143. ;user_ini.filename = ".user.ini"
  144. ; To disable this feature set this option to empty value
  145. ;user_ini.filename =
  146. ; TTL for user-defined php.ini files (time-to-live) in seconds. Default is 300 seconds (5 minutes)
  147. ;user_ini.cache_ttl = 300
  148. ;;;;;;;;;;;;;;;;;;;;
  149. ; Language Options ;
  150. ;;;;;;;;;;;;;;;;;;;;
  151. ; Enable the PHP scripting language engine under Apache.
  152. ; http://php.net/engine
  153. engine = On
  154. ; This directive determines whether or not PHP will recognize code between
  155. ; <? and ?> tags as PHP source which should be processed as such. It is
  156. ; generally recommended that <?php and ?> should be used and that this feature
  157. ; should be disabled, as enabling it may result in issues when generating XML
  158. ; documents, however this remains supported for backward compatibility reasons.
  159. ; Note that this directive does not control the <?= shorthand tag, which can be
  160. ; used regardless of this directive.
  161. ; Default Value: On
  162. ; Development Value: Off
  163. ; Production Value: Off
  164. ; http://php.net/short-open-tag
  165. short_open_tag = Off
  166. ; Allow ASP-style <% %> tags.
  167. ; http://php.net/asp-tags
  168. asp_tags = Off
  169. ; The number of significant digits displayed in floating point numbers.
  170. ; http://php.net/precision
  171. precision = 14
  172. ; Output buffering is a mechanism for controlling how much output data
  173. ; (excluding headers and cookies) PHP should keep internally before pushing that
  174. ; data to the client. If your application's output exceeds this setting, PHP
  175. ; will send that data in chunks of roughly the size you specify.
  176. ; Turning on this setting and managing its maximum buffer size can yield some
  177. ; interesting side-effects depending on your application and web server.
  178. ; You may be able to send headers and cookies after you've already sent output
  179. ; through print or echo. You also may see performance benefits if your server is
  180. ; emitting less packets due to buffered output versus PHP streaming the output
  181. ; as it gets it. On production servers, 4096 bytes is a good setting for performance
  182. ; reasons.
  183. ; Note: Output buffering can also be controlled via Output Buffering Control
  184. ; functions.
  185. ; Possible Values:
  186. ; On = Enabled and buffer is unlimited. (Use with caution)
  187. ; Off = Disabled
  188. ; Integer = Enables the buffer and sets its maximum size in bytes.
  189. ; Note: This directive is hardcoded to Off for the CLI SAPI
  190. ; Default Value: Off
  191. ; Development Value: 4096
  192. ; Production Value: 4096
  193. ; http://php.net/output-buffering
  194. output_buffering = 4096
  195. ; You can redirect all of the output of your scripts to a function. For
  196. ; example, if you set output_handler to "mb_output_handler", character
  197. ; encoding will be transparently converted to the specified encoding.
  198. ; Setting any output handler automatically turns on output buffering.
  199. ; Note: People who wrote portable scripts should not depend on this ini
  200. ; directive. Instead, explicitly set the output handler using ob_start().
  201. ; Using this ini directive may cause problems unless you know what script
  202. ; is doing.
  203. ; Note: You cannot use both "mb_output_handler" with "ob_iconv_handler"
  204. ; and you cannot use both "ob_gzhandler" and "zlib.output_compression".
  205. ; Note: output_handler must be empty if this is set 'On' !!!!
  206. ; Instead you must use zlib.output_handler.
  207. ; http://php.net/output-handler
  208. ;output_handler =
  209. ; Transparent output compression using the zlib library
  210. ; Valid values for this option are 'off', 'on', or a specific buffer size
  211. ; to be used for compression (default is 4KB)
  212. ; Note: Resulting chunk size may vary due to nature of compression. PHP
  213. ; outputs chunks that are few hundreds bytes each as a result of
  214. ; compression. If you prefer a larger chunk size for better
  215. ; performance, enable output_buffering in addition.
  216. ; Note: You need to use zlib.output_handler instead of the standard
  217. ; output_handler, or otherwise the output will be corrupted.
  218. ; http://php.net/zlib.output-compression
  219. zlib.output_compression = Off
  220. ; http://php.net/zlib.output-compression-level
  221. ;zlib.output_compression_level = -1
  222. ; You cannot specify additional output handlers if zlib.output_compression
  223. ; is activated here. This setting does the same as output_handler but in
  224. ; a different order.
  225. ; http://php.net/zlib.output-handler
  226. ;zlib.output_handler =
  227. ; Implicit flush tells PHP to tell the output layer to flush itself
  228. ; automatically after every output block. This is equivalent to calling the
  229. ; PHP function flush() after each and every call to print() or echo() and each
  230. ; and every HTML block. Turning this option on has serious performance
  231. ; implications and is generally recommended for debugging purposes only.
  232. ; http://php.net/implicit-flush
  233. ; Note: This directive is hardcoded to On for the CLI SAPI
  234. implicit_flush = Off
  235. ; The unserialize callback function will be called (with the undefined class'
  236. ; name as parameter), if the unserializer finds an undefined class
  237. ; which should be instantiated. A warning appears if the specified function is
  238. ; not defined, or if the function doesn't include/implement the missing class.
  239. ; So only set this entry, if you really want to implement such a
  240. ; callback-function.
  241. unserialize_callback_func =
  242. ; When floats & doubles are serialized store serialize_precision significant
  243. ; digits after the floating point. The default value ensures that when floats
  244. ; are decoded with unserialize, the data will remain the same.
  245. serialize_precision = 17
  246. ; open_basedir, if set, limits all file operations to the defined directory
  247. ; and below. This directive makes most sense if used in a per-directory
  248. ; or per-virtualhost web server configuration file.
  249. ; http://php.net/open-basedir
  250. ;open_basedir =
  251. ; This directive allows you to disable certain functions for security reasons.
  252. ; It receives a comma-delimited list of function names.
  253. ; http://php.net/disable-functions
  254. disable_functions =
  255. ; This directive allows you to disable certain classes for security reasons.
  256. ; It receives a comma-delimited list of class names.
  257. ; http://php.net/disable-classes
  258. disable_classes =
  259. ; Colors for Syntax Highlighting mode. Anything that's acceptable in
  260. ; <span style="color: ???????"> would work.
  261. ; http://php.net/syntax-highlighting
  262. ;highlight.string = #DD0000
  263. ;highlight.comment = #FF9900
  264. ;highlight.keyword = #007700
  265. ;highlight.default = #0000BB
  266. ;highlight.html = #000000
  267. ; If enabled, the request will be allowed to complete even if the user aborts
  268. ; the request. Consider enabling it if executing long requests, which may end up
  269. ; being interrupted by the user or a browser timing out. PHP's default behavior
  270. ; is to disable this feature.
  271. ; http://php.net/ignore-user-abort
  272. ;ignore_user_abort = On
  273. ; Determines the size of the realpath cache to be used by PHP. This value should
  274. ; be increased on systems where PHP opens many files to reflect the quantity of
  275. ; the file operations performed.
  276. ; http://php.net/realpath-cache-size
  277. ;realpath_cache_size = 16k
  278. ; Duration of time, in seconds for which to cache realpath information for a given
  279. ; file or directory. For systems with rarely changing files, consider increasing this
  280. ; value.
  281. ; http://php.net/realpath-cache-ttl
  282. ;realpath_cache_ttl = 120
  283. ; Enables or disables the circular reference collector.
  284. ; http://php.net/zend.enable-gc
  285. zend.enable_gc = On
  286. ; If enabled, scripts may be written in encodings that are incompatible with
  287. ; the scanner. CP936, Big5, CP949 and Shift_JIS are the examples of such
  288. ; encodings. To use this feature, mbstring extension must be enabled.
  289. ; Default: Off
  290. ;zend.multibyte = Off
  291. ; Allows to set the default encoding for the scripts. This value will be used
  292. ; unless "declare(encoding=...)" directive appears at the top of the script.
  293. ; Only affects if zend.multibyte is set.
  294. ; Default: ""
  295. ;zend.script_encoding =
  296. ;;;;;;;;;;;;;;;;;
  297. ; Miscellaneous ;
  298. ;;;;;;;;;;;;;;;;;
  299. ; Decides whether PHP may expose the fact that it is installed on the server
  300. ; (e.g. by adding its signature to the Web server header). It is no security
  301. ; threat in any way, but it makes it possible to determine whether you use PHP
  302. ; on your server or not.
  303. ; http://php.net/expose-php
  304. expose_php = On
  305. ;;;;;;;;;;;;;;;;;;;
  306. ; Resource Limits ;
  307. ;;;;;;;;;;;;;;;;;;;
  308. ; Maximum execution time of each script, in seconds
  309. ; http://php.net/max-execution-time
  310. ; Note: This directive is hardcoded to 0 for the CLI SAPI
  311. max_execution_time = 30
  312. ; Maximum amount of time each script may spend parsing request data. It's a good
  313. ; idea to limit this time on productions servers in order to eliminate unexpectedly
  314. ; long running scripts.
  315. ; Note: This directive is hardcoded to -1 for the CLI SAPI
  316. ; Default Value: -1 (Unlimited)
  317. ; Development Value: 60 (60 seconds)
  318. ; Production Value: 60 (60 seconds)
  319. ; http://php.net/max-input-time
  320. max_input_time = 60
  321. ; Maximum input variable nesting level
  322. ; http://php.net/max-input-nesting-level
  323. ;max_input_nesting_level = 64
  324. ; How many GET/POST/COOKIE input variables may be accepted
  325. ; max_input_vars = 1000
  326. ; Maximum amount of memory a script may consume (128MB)
  327. ; http://php.net/memory-limit
  328. memory_limit = 128M
  329. ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
  330. ; Error handling and logging ;
  331. ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
  332. ; This directive informs PHP of which errors, warnings and notices you would like
  333. ; it to take action for. The recommended way of setting values for this
  334. ; directive is through the use of the error level constants and bitwise
  335. ; operators. The error level constants are below here for convenience as well as
  336. ; some common settings and their meanings.
  337. ; By default, PHP is set to take action on all errors, notices and warnings EXCEPT
  338. ; those related to E_NOTICE and E_STRICT, which together cover best practices and
  339. ; recommended coding standards in PHP. For performance reasons, this is the
  340. ; recommend error reporting setting. Your production server shouldn't be wasting
  341. ; resources complaining about best practices and coding standards. That's what
  342. ; development servers and development settings are for.
  343. ; Note: The php.ini-development file has this setting as E_ALL. This
  344. ; means it pretty much reports everything which is exactly what you want during
  345. ; development and early testing.
  346. ;
  347. ; Error Level Constants:
  348. ; E_ALL - All errors and warnings (includes E_STRICT as of PHP 5.4.0)
  349. ; E_ERROR - fatal run-time errors
  350. ; E_RECOVERABLE_ERROR - almost fatal run-time errors
  351. ; E_WARNING - run-time warnings (non-fatal errors)
  352. ; E_PARSE - compile-time parse errors
  353. ; E_NOTICE - run-time notices (these are warnings which often result
  354. ; from a bug in your code, but it's possible that it was
  355. ; intentional (e.g., using an uninitialized variable and
  356. ; relying on the fact it is automatically initialized to an
  357. ; empty string)
  358. ; E_STRICT - run-time notices, enable to have PHP suggest changes
  359. ; to your code which will ensure the best interoperability
  360. ; and forward compatibility of your code
  361. ; E_CORE_ERROR - fatal errors that occur during PHP's initial startup
  362. ; E_CORE_WARNING - warnings (non-fatal errors) that occur during PHP's
  363. ; initial startup
  364. ; E_COMPILE_ERROR - fatal compile-time errors
  365. ; E_COMPILE_WARNING - compile-time warnings (non-fatal errors)
  366. ; E_USER_ERROR - user-generated error message
  367. ; E_USER_WARNING - user-generated warning message
  368. ; E_USER_NOTICE - user-generated notice message
  369. ; E_DEPRECATED - warn about code that will not work in future versions
  370. ; of PHP
  371. ; E_USER_DEPRECATED - user-generated deprecation warnings
  372. ;
  373. ; Common Values:
  374. ; E_ALL (Show all errors, warnings and notices including coding standards.)
  375. ; E_ALL & ~E_NOTICE (Show all errors, except for notices)
  376. ; E_ALL & ~E_NOTICE & ~E_STRICT (Show all errors, except for notices and coding standards warnings.)
  377. ; E_COMPILE_ERROR|E_RECOVERABLE_ERROR|E_ERROR|E_CORE_ERROR (Show only errors)
  378. ; Default Value: E_ALL & ~E_NOTICE & ~E_STRICT & ~E_DEPRECATED
  379. ; Development Value: E_ALL
  380. ; Production Value: E_ALL & ~E_DEPRECATED & ~E_STRICT
  381. ; http://php.net/error-reporting
  382. error_reporting = E_ALL
  383. ; This directive controls whether or not and where PHP will output errors,
  384. ; notices and warnings too. Error output is very useful during development, but
  385. ; it could be very dangerous in production environments. Depending on the code
  386. ; which is triggering the error, sensitive information could potentially leak
  387. ; out of your application such as database usernames and passwords or worse.
  388. ; For production environments, we recommend logging errors rather than
  389. ; sending them to STDOUT.
  390. ; Possible Values:
  391. ; Off = Do not display any errors
  392. ; stderr = Display errors to STDERR (affects only CGI/CLI binaries!)
  393. ; On or stdout = Display errors to STDOUT
  394. ; Default Value: On
  395. ; Development Value: On
  396. ; Production Value: Off
  397. ; http://php.net/display-errors
  398. display_errors = On
  399. ; The display of errors which occur during PHP's startup sequence are handled
  400. ; separately from display_errors. PHP's default behavior is to suppress those
  401. ; errors from clients. Turning the display of startup errors on can be useful in
  402. ; debugging configuration problems. We strongly recommend you
  403. ; set this to 'off' for production servers.
  404. ; Default Value: Off
  405. ; Development Value: On
  406. ; Production Value: Off
  407. ; http://php.net/display-startup-errors
  408. display_startup_errors = On
  409. ; Besides displaying errors, PHP can also log errors to locations such as a
  410. ; server-specific log, STDERR, or a location specified by the error_log
  411. ; directive found below. While errors should not be displayed on productions
  412. ; servers they should still be monitored and logging is a great way to do that.
  413. ; Default Value: Off
  414. ; Development Value: On
  415. ; Production Value: On
  416. ; http://php.net/log-errors
  417. log_errors = On
  418. ; Set maximum length of log_errors. In error_log information about the source is
  419. ; added. The default is 1024 and 0 allows to not apply any maximum length at all.
  420. ; http://php.net/log-errors-max-len
  421. log_errors_max_len = 1024
  422. ; Do not log repeated messages. Repeated errors must occur in same file on same
  423. ; line unless ignore_repeated_source is set true.
  424. ; http://php.net/ignore-repeated-errors
  425. ignore_repeated_errors = Off
  426. ; Ignore source of message when ignoring repeated messages. When this setting
  427. ; is On you will not log errors with repeated messages from different files or
  428. ; source lines.
  429. ; http://php.net/ignore-repeated-source
  430. ignore_repeated_source = Off
  431. ; If this parameter is set to Off, then memory leaks will not be shown (on
  432. ; stdout or in the log). This has only effect in a debug compile, and if
  433. ; error reporting includes E_WARNING in the allowed list
  434. ; http://php.net/report-memleaks
  435. report_memleaks = On
  436. ; This setting is on by default.
  437. ;report_zend_debug = 0
  438. ; Store the last error/warning message in $php_errormsg (boolean). Setting this value
  439. ; to On can assist in debugging and is appropriate for development servers. It should
  440. ; however be disabled on production servers.
  441. ; Default Value: Off
  442. ; Development Value: On
  443. ; Production Value: Off
  444. ; http://php.net/track-errors
  445. track_errors = On
  446. ; Turn off normal error reporting and emit XML-RPC error XML
  447. ; http://php.net/xmlrpc-errors
  448. ;xmlrpc_errors = 0
  449. ; An XML-RPC faultCode
  450. ;xmlrpc_error_number = 0
  451. ; When PHP displays or logs an error, it has the capability of formatting the
  452. ; error message as HTML for easier reading. This directive controls whether
  453. ; the error message is formatted as HTML or not.
  454. ; Note: This directive is hardcoded to Off for the CLI SAPI
  455. ; Default Value: On
  456. ; Development Value: On
  457. ; Production value: On
  458. ; http://php.net/html-errors
  459. html_errors = On
  460. ; If html_errors is set to On *and* docref_root is not empty, then PHP
  461. ; produces clickable error messages that direct to a page describing the error
  462. ; or function causing the error in detail.
  463. ; You can download a copy of the PHP manual from http://php.net/docs
  464. ; and change docref_root to the base URL of your local copy including the
  465. ; leading '/'. You must also specify the file extension being used including
  466. ; the dot. PHP's default behavior is to leave these settings empty, in which
  467. ; case no links to documentation are generated.
  468. ; Note: Never use this feature for production boxes.
  469. ; http://php.net/docref-root
  470. ; Examples
  471. ;docref_root = "/phpmanual/"
  472. ; http://php.net/docref-ext
  473. ;docref_ext = .html
  474. ; String to output before an error message. PHP's default behavior is to leave
  475. ; this setting blank.
  476. ; http://php.net/error-prepend-string
  477. ; Example:
  478. ;error_prepend_string = "<span style='color: #ff0000'>"
  479. ; String to output after an error message. PHP's default behavior is to leave
  480. ; this setting blank.
  481. ; http://php.net/error-append-string
  482. ; Example:
  483. ;error_append_string = "</span>"
  484. ; Log errors to specified file. PHP's default behavior is to leave this value
  485. ; empty.
  486. ; http://php.net/error-log
  487. ; Example:
  488. ;error_log = php_errors.log
  489. ; Log errors to syslog (Event Log on Windows).
  490. ;error_log = syslog
  491. ;windows.show_crt_warning
  492. ; Default value: 0
  493. ; Development value: 0
  494. ; Production value: 0
  495. ;;;;;;;;;;;;;;;;;
  496. ; Data Handling ;
  497. ;;;;;;;;;;;;;;;;;
  498. ; The separator used in PHP generated URLs to separate arguments.
  499. ; PHP's default setting is "&".
  500. ; http://php.net/arg-separator.output
  501. ; Example:
  502. ;arg_separator.output = "&amp;"
  503. ; List of separator(s) used by PHP to parse input URLs into variables.
  504. ; PHP's default setting is "&".
  505. ; NOTE: Every character in this directive is considered as separator!
  506. ; http://php.net/arg-separator.input
  507. ; Example:
  508. ;arg_separator.input = ";&"
  509. ; This directive determines which super global arrays are registered when PHP
  510. ; starts up. G,P,C,E & S are abbreviations for the following respective super
  511. ; globals: GET, POST, COOKIE, ENV and SERVER. There is a performance penalty
  512. ; paid for the registration of these arrays and because ENV is not as commonly
  513. ; used as the others, ENV is not recommended on productions servers. You
  514. ; can still get access to the environment variables through getenv() should you
  515. ; need to.
  516. ; Default Value: "EGPCS"
  517. ; Development Value: "GPCS"
  518. ; Production Value: "GPCS";
  519. ; http://php.net/variables-order
  520. variables_order = "GPCS"
  521. ; This directive determines which super global data (G,P & C) should be
  522. ; registered into the super global array REQUEST. If so, it also determines
  523. ; the order in which that data is registered. The values for this directive
  524. ; are specified in the same manner as the variables_order directive,
  525. ; EXCEPT one. Leaving this value empty will cause PHP to use the value set
  526. ; in the variables_order directive. It does not mean it will leave the super
  527. ; globals array REQUEST empty.
  528. ; Default Value: None
  529. ; Development Value: "GP"
  530. ; Production Value: "GP"
  531. ; http://php.net/request-order
  532. request_order = "GP"
  533. ; This directive determines whether PHP registers $argv & $argc each time it
  534. ; runs. $argv contains an array of all the arguments passed to PHP when a script
  535. ; is invoked. $argc contains an integer representing the number of arguments
  536. ; that were passed when the script was invoked. These arrays are extremely
  537. ; useful when running scripts from the command line. When this directive is
  538. ; enabled, registering these variables consumes CPU cycles and memory each time
  539. ; a script is executed. For performance reasons, this feature should be disabled
  540. ; on production servers.
  541. ; Note: This directive is hardcoded to On for the CLI SAPI
  542. ; Default Value: On
  543. ; Development Value: Off
  544. ; Production Value: Off
  545. ; http://php.net/register-argc-argv
  546. register_argc_argv = Off
  547. ; When enabled, the ENV, REQUEST and SERVER variables are created when they're
  548. ; first used (Just In Time) instead of when the script starts. If these
  549. ; variables are not used within a script, having this directive on will result
  550. ; in a performance gain. The PHP directive register_argc_argv must be disabled
  551. ; for this directive to have any affect.
  552. ; http://php.net/auto-globals-jit
  553. auto_globals_jit = On
  554. ; Whether PHP will read the POST data.
  555. ; This option is enabled by default.
  556. ; Most likely, you won't want to disable this option globally. It causes $_POST
  557. ; and $_FILES to always be empty; the only way you will be able to read the
  558. ; POST data will be through the php://input stream wrapper. This can be useful
  559. ; to proxy requests or to process the POST data in a memory efficient fashion.
  560. ; http://php.net/enable-post-data-reading
  561. ;enable_post_data_reading = Off
  562. ; Maximum size of POST data that PHP will accept.
  563. ; Its value may be 0 to disable the limit. It is ignored if POST data reading
  564. ; is disabled through enable_post_data_reading.
  565. ; http://php.net/post-max-size
  566. post_max_size = 8M
  567. ; Automatically add files before PHP document.
  568. ; http://php.net/auto-prepend-file
  569. auto_prepend_file =
  570. ; Automatically add files after PHP document.
  571. ; http://php.net/auto-append-file
  572. auto_append_file =
  573. ; By default, PHP will output a media type using the Content-Type header. To
  574. ; disable this, simply set it to be empty.
  575. ;
  576. ; PHP's built-in default media type is set to text/html.
  577. ; http://php.net/default-mimetype
  578. default_mimetype = "text/html"
  579. ; PHP's default character set is set to UTF-8.
  580. ; http://php.net/default-charset
  581. default_charset = "UTF-8"
  582. ; PHP internal character encoding is set to empty.
  583. ; If empty, default_charset is used.
  584. ; http://php.net/internal-encoding
  585. ;internal_encoding =
  586. ; PHP input character encoding is set to empty.
  587. ; If empty, default_charset is used.
  588. ; http://php.net/input-encoding
  589. ;input_encoding =
  590. ; PHP output character encoding is set to empty.
  591. ; If empty, default_charset is used.
  592. ; See also output_buffer.
  593. ; http://php.net/output-encoding
  594. ;output_encoding =
  595. ; Always populate the $HTTP_RAW_POST_DATA variable. PHP's default behavior is
  596. ; to disable this feature and it will be removed in a future version.
  597. ; If post reading is disabled through enable_post_data_reading,
  598. ; $HTTP_RAW_POST_DATA is *NOT* populated.
  599. ; http://php.net/always-populate-raw-post-data
  600. ;always_populate_raw_post_data = -1
  601. ;;;;;;;;;;;;;;;;;;;;;;;;;
  602. ; Paths and Directories ;
  603. ;;;;;;;;;;;;;;;;;;;;;;;;;
  604. ; UNIX: "/path1:/path2"
  605. ;include_path = ".:/php/includes"
  606. ;
  607. ; Windows: "\path1;\path2"
  608. ;include_path = ".;c:\php\includes"
  609. ;
  610. ; PHP's default setting for include_path is ".;/path/to/php/pear"
  611. ; http://php.net/include-path
  612. ; The root of the PHP pages, used only if nonempty.
  613. ; if PHP was not compiled with FORCE_REDIRECT, you SHOULD set doc_root
  614. ; if you are running php as a CGI under any web server (other than IIS)
  615. ; see documentation for security issues. The alternate is to use the
  616. ; cgi.force_redirect configuration below
  617. ; http://php.net/doc-root
  618. doc_root =
  619. ; The directory under which PHP opens the script using /~username used only
  620. ; if nonempty.
  621. ; http://php.net/user-dir
  622. user_dir =
  623. ; Directory in which the loadable extensions (modules) reside.
  624. ; http://php.net/extension-dir
  625. ; extension_dir = "./"
  626. ; On windows:
  627. ; extension_dir = "ext"
  628. ; Directory where the temporary files should be placed.
  629. ; Defaults to the system default (see sys_get_temp_dir)
  630. ; sys_temp_dir = "/tmp"
  631. ; Whether or not to enable the dl() function. The dl() function does NOT work
  632. ; properly in multithreaded servers, such as IIS or Zeus, and is automatically
  633. ; disabled on them.
  634. ; http://php.net/enable-dl
  635. enable_dl = Off
  636. ; cgi.force_redirect is necessary to provide security running PHP as a CGI under
  637. ; most web servers. Left undefined, PHP turns this on by default. You can
  638. ; turn it off here AT YOUR OWN RISK
  639. ; **You CAN safely turn this off for IIS, in fact, you MUST.**
  640. ; http://php.net/cgi.force-redirect
  641. ;cgi.force_redirect = 1
  642. ; if cgi.nph is enabled it will force cgi to always sent Status: 200 with
  643. ; every request. PHP's default behavior is to disable this feature.
  644. ;cgi.nph = 1
  645. ; if cgi.force_redirect is turned on, and you are not running under Apache or Netscape
  646. ; (iPlanet) web servers, you MAY need to set an environment variable name that PHP
  647. ; will look for to know it is OK to continue execution. Setting this variable MAY
  648. ; cause security issues, KNOW WHAT YOU ARE DOING FIRST.
  649. ; http://php.net/cgi.redirect-status-env
  650. ;cgi.redirect_status_env =
  651. ; cgi.fix_pathinfo provides *real* PATH_INFO/PATH_TRANSLATED support for CGI. PHP's
  652. ; previous behaviour was to set PATH_TRANSLATED to SCRIPT_FILENAME, and to not grok
  653. ; what PATH_INFO is. For more information on PATH_INFO, see the cgi specs. Setting
  654. ; this to 1 will cause PHP CGI to fix its paths to conform to the spec. A setting
  655. ; of zero causes PHP to behave as before. Default is 1. You should fix your scripts
  656. ; to use SCRIPT_FILENAME rather than PATH_TRANSLATED.
  657. ; http://php.net/cgi.fix-pathinfo
  658. ;cgi.fix_pathinfo=1
  659. ; if cgi.discard_path is enabled, the PHP CGI binary can safely be placed outside
  660. ; of the web tree and people will not be able to circumvent .htaccess security.
  661. ; http://php.net/cgi.dicard-path
  662. ;cgi.discard_path=1
  663. ; FastCGI under IIS (on WINNT based OS) supports the ability to impersonate
  664. ; security tokens of the calling client. This allows IIS to define the
  665. ; security context that the request runs under. mod_fastcgi under Apache
  666. ; does not currently support this feature (03/17/2002)
  667. ; Set to 1 if running under IIS. Default is zero.
  668. ; http://php.net/fastcgi.impersonate
  669. ;fastcgi.impersonate = 1
  670. ; Disable logging through FastCGI connection. PHP's default behavior is to enable
  671. ; this feature.
  672. ;fastcgi.logging = 0
  673. ; cgi.rfc2616_headers configuration option tells PHP what type of headers to
  674. ; use when sending HTTP response code. If set to 0, PHP sends Status: header that
  675. ; is supported by Apache. When this option is set to 1, PHP will send
  676. ; RFC2616 compliant header.
  677. ; Default is zero.
  678. ; http://php.net/cgi.rfc2616-headers
  679. ;cgi.rfc2616_headers = 0
  680. ; cgi.check_shebang_line controls whether CGI PHP checks for line starting with #!
  681. ; (shebang) at the top of the running script. This line might be needed if the
  682. ; script support running both as stand-alone script and via PHP CGI<. PHP in CGI
  683. ; mode skips this line and ignores its content if this directive is turned on.
  684. ; http://php.net/cgi.check-shebang-line
  685. ;cgi.check_shebang_line=1
  686. ;;;;;;;;;;;;;;;;
  687. ; File Uploads ;
  688. ;;;;;;;;;;;;;;;;
  689. ; Whether to allow HTTP file uploads.
  690. ; http://php.net/file-uploads
  691. file_uploads = On
  692. ; Temporary directory for HTTP uploaded files (will use system default if not
  693. ; specified).
  694. ; http://php.net/upload-tmp-dir
  695. ;upload_tmp_dir =
  696. ; Maximum allowed size for uploaded files.
  697. ; http://php.net/upload-max-filesize
  698. upload_max_filesize = 2M
  699. ; Maximum number of files that can be uploaded via a single request
  700. max_file_uploads = 20
  701. ;;;;;;;;;;;;;;;;;;
  702. ; Fopen wrappers ;
  703. ;;;;;;;;;;;;;;;;;;
  704. ; Whether to allow the treatment of URLs (like http:// or ftp://) as files.
  705. ; http://php.net/allow-url-fopen
  706. allow_url_fopen = On
  707. ; Whether to allow include/require to open URLs (like http:// or ftp://) as files.
  708. ; http://php.net/allow-url-include
  709. allow_url_include = Off
  710. ; Define the anonymous ftp password (your email address). PHP's default setting
  711. ; for this is empty.
  712. ; http://php.net/from
  713. ;from="john@doe.com"
  714. ; Define the User-Agent string. PHP's default setting for this is empty.
  715. ; http://php.net/user-agent
  716. ;user_agent="PHP"
  717. ; Default timeout for socket based streams (seconds)
  718. ; http://php.net/default-socket-timeout
  719. default_socket_timeout = 60
  720. ; If your scripts have to deal with files from Macintosh systems,
  721. ; or you are running on a Mac and need to deal with files from
  722. ; unix or win32 systems, setting this flag will cause PHP to
  723. ; automatically detect the EOL character in those files so that
  724. ; fgets() and file() will work regardless of the source of the file.
  725. ; http://php.net/auto-detect-line-endings
  726. ;auto_detect_line_endings = Off
  727. ;;;;;;;;;;;;;;;;;;;;;;
  728. ; Dynamic Extensions ;
  729. ;;;;;;;;;;;;;;;;;;;;;;
  730. ; If you wish to have an extension loaded automatically, use the following
  731. ; syntax:
  732. ;
  733. ; extension=modulename.extension
  734. ;
  735. ; For example, on Windows:
  736. ;
  737. ; extension=msql.dll
  738. ;
  739. ; ... or under UNIX:
  740. ;
  741. ; extension=msql.so
  742. ;
  743. ; ... or with a path:
  744. ;
  745. ; extension=/path/to/extension/msql.so
  746. ;
  747. ; If you only provide the name of the extension, PHP will look for it in its
  748. ; default extension directory.
  749. ;
  750. ; Windows Extensions
  751. ; Note that ODBC support is built in, so no dll is needed for it.
  752. ; Note that many DLL files are located in the extensions/ (PHP 4) ext/ (PHP 5)
  753. ; extension folders as well as the separate PECL DLL download (PHP 5).
  754. ; Be sure to appropriately set the extension_dir directive.
  755. ;
  756. ;extension=php_bz2.dll
  757. ;extension=php_curl.dll
  758. ;extension=php_fileinfo.dll
  759. ;extension=php_gd2.dll
  760. ;extension=php_gettext.dll
  761. ;extension=php_gmp.dll
  762. ;extension=php_intl.dll
  763. ;extension=php_imap.dll
  764. ;extension=php_interbase.dll
  765. ;extension=php_ldap.dll
  766. ;extension=php_mbstring.dll
  767. ;extension=php_exif.dll ; Must be after mbstring as it depends on it
  768. ;extension=php_mysql.dll
  769. ;extension=php_mysqli.dll
  770. ;extension=php_oci8_12c.dll ; Use with Oracle Database 12c Instant Client
  771. ;extension=php_openssl.dll
  772. ;extension=php_pdo_firebird.dll
  773. ;extension=php_pdo_mysql.dll
  774. ;extension=php_pdo_oci.dll
  775. ;extension=php_pdo_odbc.dll
  776. ;extension=php_pdo_pgsql.dll
  777. ;extension=php_pdo_sqlite.dll
  778. ;extension=php_pgsql.dll
  779. ;extension=php_shmop.dll
  780. ; The MIBS data available in the PHP distribution must be installed.
  781. ; See http://www.php.net/manual/en/snmp.installation.php
  782. ;extension=php_snmp.dll
  783. ;extension=php_soap.dll
  784. ;extension=php_sockets.dll
  785. ;extension=php_sqlite3.dll
  786. ;extension=php_sybase_ct.dll
  787. ;extension=php_tidy.dll
  788. ;extension=php_xmlrpc.dll
  789. ;extension=php_xsl.dll
  790. ;;;;;;;;;;;;;;;;;;;
  791. ; Module Settings ;
  792. ;;;;;;;;;;;;;;;;;;;
  793. [CLI Server]
  794. ; Whether the CLI web server uses ANSI color coding in its terminal output.
  795. cli_server.color = On
  796. [Date]
  797. ; Defines the default timezone used by the date functions
  798. ; http://php.net/date.timezone
  799. date.timezone = Asia/Shanghai
  800. ; http://php.net/date.default-latitude
  801. ;date.default_latitude = 31.7667
  802. ; http://php.net/date.default-longitude
  803. ;date.default_longitude = 35.2333
  804. ; http://php.net/date.sunrise-zenith
  805. ;date.sunrise_zenith = 90.583333
  806. ; http://php.net/date.sunset-zenith
  807. ;date.sunset_zenith = 90.583333
  808. [filter]
  809. ; http://php.net/filter.default
  810. ;filter.default = unsafe_raw
  811. ; http://php.net/filter.default-flags
  812. ;filter.default_flags =
  813. [iconv]
  814. ; Use of this INI entry is deprecated, use global input_encoding instead.
  815. ; If empty, default_charset or input_encoding or iconv.input_encoding is used.
  816. ; The precedence is: default_charset < intput_encoding < iconv.input_encoding
  817. ;iconv.input_encoding =
  818. ; Use of this INI entry is deprecated, use global internal_encoding instead.
  819. ; If empty, default_charset or internal_encoding or iconv.internal_encoding is used.
  820. ; The precedence is: default_charset < internal_encoding < iconv.internal_encoding
  821. ;iconv.internal_encoding =
  822. ; Use of this INI entry is deprecated, use global output_encoding instead.
  823. ; If empty, default_charset or output_encoding or iconv.output_encoding is used.
  824. ; The precedence is: default_charset < output_encoding < iconv.output_encoding
  825. ; To use an output encoding conversion, iconv's output handler must be set
  826. ; otherwise output encoding conversion cannot be performed.
  827. ;iconv.output_encoding =
  828. [intl]
  829. ;intl.default_locale =
  830. ; This directive allows you to produce PHP errors when some error
  831. ; happens within intl functions. The value is the level of the error produced.
  832. ; Default is 0, which does not produce any errors.
  833. ;intl.error_level = E_WARNING
  834. ;intl.use_exceptions = 0
  835. [sqlite3]
  836. ;sqlite3.extension_dir =
  837. [Pcre]
  838. ;PCRE library backtracking limit.
  839. ; http://php.net/pcre.backtrack-limit
  840. ;pcre.backtrack_limit=100000
  841. ;PCRE library recursion limit.
  842. ;Please note that if you set this value to a high number you may consume all
  843. ;the available process stack and eventually crash PHP (due to reaching the
  844. ;stack size limit imposed by the Operating System).
  845. ; http://php.net/pcre.recursion-limit
  846. ;pcre.recursion_limit=100000
  847. [Pdo]
  848. ; Whether to pool ODBC connections. Can be one of "strict", "relaxed" or "off"
  849. ; http://php.net/pdo-odbc.connection-pooling
  850. ;pdo_odbc.connection_pooling=strict
  851. ;pdo_odbc.db2_instance_name
  852. [Pdo_mysql]
  853. ; If mysqlnd is used: Number of cache slots for the internal result set cache
  854. ; http://php.net/pdo_mysql.cache_size
  855. pdo_mysql.cache_size = 2000
  856. ; Default socket name for local MySQL connects. If empty, uses the built-in
  857. ; MySQL defaults.
  858. ; http://php.net/pdo_mysql.default-socket
  859. pdo_mysql.default_socket=
  860. [Phar]
  861. ; http://php.net/phar.readonly
  862. ;phar.readonly = On
  863. ; http://php.net/phar.require-hash
  864. ;phar.require_hash = On
  865. ;phar.cache_list =
  866. [mail function]
  867. ; For Win32 only.
  868. ; http://php.net/smtp
  869. SMTP = localhost
  870. ; http://php.net/smtp-port
  871. smtp_port = 25
  872. ; For Win32 only.
  873. ; http://php.net/sendmail-from
  874. ;sendmail_from = me@example.com
  875. ; For Unix only. You may supply arguments as well (default: "sendmail -t -i").
  876. ; http://php.net/sendmail-path
  877. ;sendmail_path =
  878. ; Force the addition of the specified parameters to be passed as extra parameters
  879. ; to the sendmail binary. These parameters will always replace the value of
  880. ; the 5th parameter to mail().
  881. ;mail.force_extra_parameters =
  882. ; Add X-PHP-Originating-Script: that will include uid of the script followed by the filename
  883. mail.add_x_header = On
  884. ; The path to a log file that will log all mail() calls. Log entries include
  885. ; the full path of the script, line number, To address and headers.
  886. ;mail.log =
  887. ; Log mail to syslog (Event Log on Windows).
  888. ;mail.log = syslog
  889. [SQL]
  890. ; http://php.net/sql.safe-mode
  891. sql.safe_mode = Off
  892. [ODBC]
  893. ; http://php.net/odbc.default-db
  894. ;odbc.default_db = Not yet implemented
  895. ; http://php.net/odbc.default-user
  896. ;odbc.default_user = Not yet implemented
  897. ; http://php.net/odbc.default-pw
  898. ;odbc.default_pw = Not yet implemented
  899. ; Controls the ODBC cursor model.
  900. ; Default: SQL_CURSOR_STATIC (default).
  901. ;odbc.default_cursortype
  902. ; Allow or prevent persistent links.
  903. ; http://php.net/odbc.allow-persistent
  904. odbc.allow_persistent = On
  905. ; Check that a connection is still valid before reuse.
  906. ; http://php.net/odbc.check-persistent
  907. odbc.check_persistent = On
  908. ; Maximum number of persistent links. -1 means no limit.
  909. ; http://php.net/odbc.max-persistent
  910. odbc.max_persistent = -1
  911. ; Maximum number of links (persistent + non-persistent). -1 means no limit.
  912. ; http://php.net/odbc.max-links
  913. odbc.max_links = -1
  914. ; Handling of LONG fields. Returns number of bytes to variables. 0 means
  915. ; passthru.
  916. ; http://php.net/odbc.defaultlrl
  917. odbc.defaultlrl = 4096
  918. ; Handling of binary data. 0 means passthru, 1 return as is, 2 convert to char.
  919. ; See the documentation on odbc_binmode and odbc_longreadlen for an explanation
  920. ; of odbc.defaultlrl and odbc.defaultbinmode
  921. ; http://php.net/odbc.defaultbinmode
  922. odbc.defaultbinmode = 1
  923. ;birdstep.max_links = -1
  924. [Interbase]
  925. ; Allow or prevent persistent links.
  926. ibase.allow_persistent = 1
  927. ; Maximum number of persistent links. -1 means no limit.
  928. ibase.max_persistent = -1
  929. ; Maximum number of links (persistent + non-persistent). -1 means no limit.
  930. ibase.max_links = -1
  931. ; Default database name for ibase_connect().
  932. ;ibase.default_db =
  933. ; Default username for ibase_connect().
  934. ;ibase.default_user =
  935. ; Default password for ibase_connect().
  936. ;ibase.default_password =
  937. ; Default charset for ibase_connect().
  938. ;ibase.default_charset =
  939. ; Default timestamp format.
  940. ibase.timestampformat = "%Y-%m-%d %H:%M:%S"
  941. ; Default date format.
  942. ibase.dateformat = "%Y-%m-%d"
  943. ; Default time format.
  944. ibase.timeformat = "%H:%M:%S"
  945. [MySQL]
  946. ; Allow accessing, from PHP's perspective, local files with LOAD DATA statements
  947. ; http://php.net/mysql.allow_local_infile
  948. mysql.allow_local_infile = On
  949. ; Allow or prevent persistent links.
  950. ; http://php.net/mysql.allow-persistent
  951. mysql.allow_persistent = On
  952. ; If mysqlnd is used: Number of cache slots for the internal result set cache
  953. ; http://php.net/mysql.cache_size
  954. mysql.cache_size = 2000
  955. ; Maximum number of persistent links. -1 means no limit.
  956. ; http://php.net/mysql.max-persistent
  957. mysql.max_persistent = -1
  958. ; Maximum number of links (persistent + non-persistent). -1 means no limit.
  959. ; http://php.net/mysql.max-links
  960. mysql.max_links = -1
  961. ; Default port number for mysql_connect(). If unset, mysql_connect() will use
  962. ; the $MYSQL_TCP_PORT or the mysql-tcp entry in /etc/services or the
  963. ; compile-time value defined MYSQL_PORT (in that order). Win32 will only look
  964. ; at MYSQL_PORT.
  965. ; http://php.net/mysql.default-port
  966. mysql.default_port =
  967. ; Default socket name for local MySQL connects. If empty, uses the built-in
  968. ; MySQL defaults.
  969. ; http://php.net/mysql.default-socket
  970. mysql.default_socket =
  971. ; Default host for mysql_connect() (doesn't apply in safe mode).
  972. ; http://php.net/mysql.default-host
  973. mysql.default_host =
  974. ; Default user for mysql_connect() (doesn't apply in safe mode).
  975. ; http://php.net/mysql.default-user
  976. mysql.default_user =
  977. ; Default password for mysql_connect() (doesn't apply in safe mode).
  978. ; Note that this is generally a *bad* idea to store passwords in this file.
  979. ; *Any* user with PHP access can run 'echo get_cfg_var("mysql.default_password")
  980. ; and reveal this password! And of course, any users with read access to this
  981. ; file will be able to reveal the password as well.
  982. ; http://php.net/mysql.default-password
  983. mysql.default_password =
  984. ; Maximum time (in seconds) for connect timeout. -1 means no limit
  985. ; http://php.net/mysql.connect-timeout
  986. mysql.connect_timeout = 60
  987. ; Trace mode. When trace_mode is active (=On), warnings for table/index scans and
  988. ; SQL-Errors will be displayed.
  989. ; http://php.net/mysql.trace-mode
  990. mysql.trace_mode = Off
  991. [MySQLi]
  992. ; Maximum number of persistent links. -1 means no limit.
  993. ; http://php.net/mysqli.max-persistent
  994. mysqli.max_persistent = -1
  995. ; Allow accessing, from PHP's perspective, local files with LOAD DATA statements
  996. ; http://php.net/mysqli.allow_local_infile
  997. ;mysqli.allow_local_infile = On
  998. ; Allow or prevent persistent links.
  999. ; http://php.net/mysqli.allow-persistent
  1000. mysqli.allow_persistent = On
  1001. ; Maximum number of links. -1 means no limit.
  1002. ; http://php.net/mysqli.max-links
  1003. mysqli.max_links = -1
  1004. ; If mysqlnd is used: Number of cache slots for the internal result set cache
  1005. ; http://php.net/mysqli.cache_size
  1006. mysqli.cache_size = 2000
  1007. ; Default port number for mysqli_connect(). If unset, mysqli_connect() will use
  1008. ; the $MYSQL_TCP_PORT or the mysql-tcp entry in /etc/services or the
  1009. ; compile-time value defined MYSQL_PORT (in that order). Win32 will only look
  1010. ; at MYSQL_PORT.
  1011. ; http://php.net/mysqli.default-port
  1012. mysqli.default_port = 3306
  1013. ; Default socket name for local MySQL connects. If empty, uses the built-in
  1014. ; MySQL defaults.
  1015. ; http://php.net/mysqli.default-socket
  1016. mysqli.default_socket =
  1017. ; Default host for mysql_connect() (doesn't apply in safe mode).
  1018. ; http://php.net/mysqli.default-host
  1019. mysqli.default_host =
  1020. ; Default user for mysql_connect() (doesn't apply in safe mode).
  1021. ; http://php.net/mysqli.default-user
  1022. mysqli.default_user =
  1023. ; Default password for mysqli_connect() (doesn't apply in safe mode).
  1024. ; Note that this is generally a *bad* idea to store passwords in this file.
  1025. ; *Any* user with PHP access can run 'echo get_cfg_var("mysqli.default_pw")
  1026. ; and reveal this password! And of course, any users with read access to this
  1027. ; file will be able to reveal the password as well.
  1028. ; http://php.net/mysqli.default-pw
  1029. mysqli.default_pw =
  1030. ; Allow or prevent reconnect
  1031. mysqli.reconnect = Off
  1032. [mysqlnd]
  1033. ; Enable / Disable collection of general statistics by mysqlnd which can be
  1034. ; used to tune and monitor MySQL operations.
  1035. ; http://php.net/mysqlnd.collect_statistics
  1036. mysqlnd.collect_statistics = On
  1037. ; Enable / Disable collection of memory usage statistics by mysqlnd which can be
  1038. ; used to tune and monitor MySQL operations.
  1039. ; http://php.net/mysqlnd.collect_memory_statistics
  1040. mysqlnd.collect_memory_statistics = On
  1041. ; Records communication from all extensions using mysqlnd to the specified log
  1042. ; file.
  1043. ; http://php.net/mysqlnd.debug
  1044. ;mysqlnd.debug =
  1045. ; Defines which queries will be logged.
  1046. ; http://php.net/mysqlnd.log_mask
  1047. ;mysqlnd.log_mask = 0
  1048. ; Default size of the mysqlnd memory pool, which is used by result sets.
  1049. ; http://php.net/mysqlnd.mempool_default_size
  1050. ;mysqlnd.mempool_default_size = 16000
  1051. ; Size of a pre-allocated buffer used when sending commands to MySQL in bytes.
  1052. ; http://php.net/mysqlnd.net_cmd_buffer_size
  1053. ;mysqlnd.net_cmd_buffer_size = 2048
  1054. ; Size of a pre-allocated buffer used for reading data sent by the server in
  1055. ; bytes.
  1056. ; http://php.net/mysqlnd.net_read_buffer_size
  1057. ;mysqlnd.net_read_buffer_size = 32768
  1058. ; Timeout for network requests in seconds.
  1059. ; http://php.net/mysqlnd.net_read_timeout
  1060. ;mysqlnd.net_read_timeout = 31536000
  1061. ; SHA-256 Authentication Plugin related. File with the MySQL server public RSA
  1062. ; key.
  1063. ; http://php.net/mysqlnd.sha256_server_public_key
  1064. ;mysqlnd.sha256_server_public_key =
  1065. [OCI8]
  1066. ; Connection: Enables privileged connections using external
  1067. ; credentials (OCI_SYSOPER, OCI_SYSDBA)
  1068. ; http://php.net/oci8.privileged-connect
  1069. ;oci8.privileged_connect = Off
  1070. ; Connection: The maximum number of persistent OCI8 connections per
  1071. ; process. Using -1 means no limit.
  1072. ; http://php.net/oci8.max-persistent
  1073. ;oci8.max_persistent = -1
  1074. ; Connection: The maximum number of seconds a process is allowed to
  1075. ; maintain an idle persistent connection. Using -1 means idle
  1076. ; persistent connections will be maintained forever.
  1077. ; http://php.net/oci8.persistent-timeout
  1078. ;oci8.persistent_timeout = -1
  1079. ; Connection: The number of seconds that must pass before issuing a
  1080. ; ping during oci_pconnect() to check the connection validity. When
  1081. ; set to 0, each oci_pconnect() will cause a ping. Using -1 disables
  1082. ; pings completely.
  1083. ; http://php.net/oci8.ping-interval
  1084. ;oci8.ping_interval = 60
  1085. ; Connection: Set this to a user chosen connection class to be used
  1086. ; for all pooled server requests with Oracle 11g Database Resident
  1087. ; Connection Pooling (DRCP). To use DRCP, this value should be set to
  1088. ; the same string for all web servers running the same application,
  1089. ; the database pool must be configured, and the connection string must
  1090. ; specify to use a pooled server.
  1091. ;oci8.connection_class =
  1092. ; High Availability: Using On lets PHP receive Fast Application
  1093. ; Notification (FAN) events generated when a database node fails. The
  1094. ; database must also be configured to post FAN events.
  1095. ;oci8.events = Off
  1096. ; Tuning: This option enables statement caching, and specifies how
  1097. ; many statements to cache. Using 0 disables statement caching.
  1098. ; http://php.net/oci8.statement-cache-size
  1099. ;oci8.statement_cache_size = 20
  1100. ; Tuning: Enables statement prefetching and sets the default number of
  1101. ; rows that will be fetched automatically after statement execution.
  1102. ; http://php.net/oci8.default-prefetch
  1103. ;oci8.default_prefetch = 100
  1104. ; Compatibility. Using On means oci_close() will not close
  1105. ; oci_connect() and oci_new_connect() connections.
  1106. ; http://php.net/oci8.old-oci-close-semantics
  1107. ;oci8.old_oci_close_semantics = Off
  1108. [PostgreSQL]
  1109. ; Allow or prevent persistent links.
  1110. ; http://php.net/pgsql.allow-persistent
  1111. pgsql.allow_persistent = On
  1112. ; Detect broken persistent links always with pg_pconnect().
  1113. ; Auto reset feature requires a little overheads.
  1114. ; http://php.net/pgsql.auto-reset-persistent
  1115. pgsql.auto_reset_persistent = Off
  1116. ; Maximum number of persistent links. -1 means no limit.
  1117. ; http://php.net/pgsql.max-persistent
  1118. pgsql.max_persistent = -1
  1119. ; Maximum number of links (persistent+non persistent). -1 means no limit.
  1120. ; http://php.net/pgsql.max-links
  1121. pgsql.max_links = -1
  1122. ; Ignore PostgreSQL backends Notice message or not.
  1123. ; Notice message logging require a little overheads.
  1124. ; http://php.net/pgsql.ignore-notice
  1125. pgsql.ignore_notice = 0
  1126. ; Log PostgreSQL backends Notice message or not.
  1127. ; Unless pgsql.ignore_notice=0, module cannot log notice message.
  1128. ; http://php.net/pgsql.log-notice
  1129. pgsql.log_notice = 0
  1130. [Sybase-CT]
  1131. ; Allow or prevent persistent links.
  1132. ; http://php.net/sybct.allow-persistent
  1133. sybct.allow_persistent = On
  1134. ; Maximum number of persistent links. -1 means no limit.
  1135. ; http://php.net/sybct.max-persistent
  1136. sybct.max_persistent = -1
  1137. ; Maximum number of links (persistent + non-persistent). -1 means no limit.
  1138. ; http://php.net/sybct.max-links
  1139. sybct.max_links = -1
  1140. ; Minimum server message severity to display.
  1141. ; http://php.net/sybct.min-server-severity
  1142. sybct.min_server_severity = 10
  1143. ; Minimum client message severity to display.
  1144. ; http://php.net/sybct.min-client-severity
  1145. sybct.min_client_severity = 10
  1146. ; Set per-context timeout
  1147. ; http://php.net/sybct.timeout
  1148. ;sybct.timeout=
  1149. ;sybct.packet_size
  1150. ; The maximum time in seconds to wait for a connection attempt to succeed before returning failure.
  1151. ; Default: one minute
  1152. ;sybct.login_timeout=
  1153. ; The name of the host you claim to be connecting from, for display by sp_who.
  1154. ; Default: none
  1155. ;sybct.hostname=
  1156. ; Allows you to define how often deadlocks are to be retried. -1 means "forever".
  1157. ; Default: 0
  1158. ;sybct.deadlock_retry_count=
  1159. [bcmath]
  1160. ; Number of decimal digits for all bcmath functions.
  1161. ; http://php.net/bcmath.scale
  1162. bcmath.scale = 0
  1163. [browscap]
  1164. ; http://php.net/browscap
  1165. ;browscap = extra/browscap.ini
  1166. [Session]
  1167. ; Handler used to store/retrieve data.
  1168. ; http://php.net/session.save-handler
  1169. session.save_handler = files
  1170. ; Argument passed to save_handler. In the case of files, this is the path
  1171. ; where data files are stored. Note: Windows users have to change this
  1172. ; variable in order to use PHP's session functions.
  1173. ;
  1174. ; The path can be defined as:
  1175. ;
  1176. ; session.save_path = "N;/path"
  1177. ;
  1178. ; where N is an integer. Instead of storing all the session files in
  1179. ; /path, what this will do is use subdirectories N-levels deep, and
  1180. ; store the session data in those directories. This is useful if
  1181. ; your OS has problems with many files in one directory, and is
  1182. ; a more efficient layout for servers that handle many sessions.
  1183. ;
  1184. ; NOTE 1: PHP will not create this directory structure automatically.
  1185. ; You can use the script in the ext/session dir for that purpose.
  1186. ; NOTE 2: See the section on garbage collection below if you choose to
  1187. ; use subdirectories for session storage
  1188. ;
  1189. ; The file storage module creates files using mode 600 by default.
  1190. ; You can change that by using
  1191. ;
  1192. ; session.save_path = "N;MODE;/path"
  1193. ;
  1194. ; where MODE is the octal representation of the mode. Note that this
  1195. ; does not overwrite the process's umask.
  1196. ; http://php.net/session.save-path
  1197. ;session.save_path = "/tmp"
  1198. ; Whether to use strict session mode.
  1199. ; Strict session mode does not accept uninitialized session ID and regenerate
  1200. ; session ID if browser sends uninitialized session ID. Strict mode protects
  1201. ; applications from session fixation via session adoption vulnerability. It is
  1202. ; disabled by default for maximum compatibility, but enabling it is encouraged.
  1203. ; https://wiki.php.net/rfc/strict_sessions
  1204. session.use_strict_mode = 0
  1205. ; Whether to use cookies.
  1206. ; http://php.net/session.use-cookies
  1207. session.use_cookies = 1
  1208. ; http://php.net/session.cookie-secure
  1209. ;session.cookie_secure =
  1210. ; This option forces PHP to fetch and use a cookie for storing and maintaining
  1211. ; the session id. We encourage this operation as it's very helpful in combating
  1212. ; session hijacking when not specifying and managing your own session id. It is
  1213. ; not the be-all and end-all of session hijacking defense, but it's a good start.
  1214. ; http://php.net/session.use-only-cookies
  1215. session.use_only_cookies = 1
  1216. ; Name of the session (used as cookie name).
  1217. ; http://php.net/session.name
  1218. session.name = PHPSESSID
  1219. ; Initialize session on request startup.
  1220. ; http://php.net/session.auto-start
  1221. session.auto_start = 0
  1222. ; Lifetime in seconds of cookie or, if 0, until browser is restarted.
  1223. ; http://php.net/session.cookie-lifetime
  1224. session.cookie_lifetime = 0
  1225. ; The path for which the cookie is valid.
  1226. ; http://php.net/session.cookie-path
  1227. session.cookie_path = /
  1228. ; The domain for which the cookie is valid.
  1229. ; http://php.net/session.cookie-domain
  1230. session.cookie_domain =
  1231. ; Whether or not to add the httpOnly flag to the cookie, which makes it inaccessible to browser scripting languages such as JavaScript.
  1232. ; http://php.net/session.cookie-httponly
  1233. session.cookie_httponly =
  1234. ; Handler used to serialize data. php is the standard serializer of PHP.
  1235. ; http://php.net/session.serialize-handler
  1236. session.serialize_handler = php
  1237. ; Defines the probability that the 'garbage collection' process is started
  1238. ; on every session initialization. The probability is calculated by using
  1239. ; gc_probability/gc_divisor. Where session.gc_probability is the numerator
  1240. ; and gc_divisor is the denominator in the equation. Setting this value to 1
  1241. ; when the session.gc_divisor value is 100 will give you approximately a 1% chance
  1242. ; the gc will run on any give request.
  1243. ; Default Value: 1
  1244. ; Development Value: 1
  1245. ; Production Value: 1
  1246. ; http://php.net/session.gc-probability
  1247. session.gc_probability = 1
  1248. ; Defines the probability that the 'garbage collection' process is started on every
  1249. ; session initialization. The probability is calculated by using the following equation:
  1250. ; gc_probability/gc_divisor. Where session.gc_probability is the numerator and
  1251. ; session.gc_divisor is the denominator in the equation. Setting this value to 1
  1252. ; when the session.gc_divisor value is 100 will give you approximately a 1% chance
  1253. ; the gc will run on any give request. Increasing this value to 1000 will give you
  1254. ; a 0.1% chance the gc will run on any give request. For high volume production servers,
  1255. ; this is a more efficient approach.
  1256. ; Default Value: 100
  1257. ; Development Value: 1000
  1258. ; Production Value: 1000
  1259. ; http://php.net/session.gc-divisor
  1260. session.gc_divisor = 1000
  1261. ; After this number of seconds, stored data will be seen as 'garbage' and
  1262. ; cleaned up by the garbage collection process.
  1263. ; http://php.net/session.gc-maxlifetime
  1264. session.gc_maxlifetime = 1440
  1265. ; NOTE: If you are using the subdirectory option for storing session files
  1266. ; (see session.save_path above), then garbage collection does *not*
  1267. ; happen automatically. You will need to do your own garbage
  1268. ; collection through a shell script, cron entry, or some other method.
  1269. ; For example, the following script would is the equivalent of
  1270. ; setting session.gc_maxlifetime to 1440 (1440 seconds = 24 minutes):
  1271. ; find /path/to/sessions -cmin +24 -type f | xargs rm
  1272. ; Check HTTP Referer to invalidate externally stored URLs containing ids.
  1273. ; HTTP_REFERER has to contain this substring for the session to be
  1274. ; considered as valid.
  1275. ; http://php.net/session.referer-check
  1276. session.referer_check =
  1277. ; How many bytes to read from the file.
  1278. ; http://php.net/session.entropy-length
  1279. ;session.entropy_length = 32
  1280. ; Specified here to create the session id.
  1281. ; http://php.net/session.entropy-file
  1282. ; Defaults to /dev/urandom
  1283. ; On systems that don't have /dev/urandom but do have /dev/arandom, this will default to /dev/arandom
  1284. ; If neither are found at compile time, the default is no entropy file.
  1285. ; On windows, setting the entropy_length setting will activate the
  1286. ; Windows random source (using the CryptoAPI)
  1287. ;session.entropy_file = /dev/urandom
  1288. ; Set to {nocache,private,public,} to determine HTTP caching aspects
  1289. ; or leave this empty to avoid sending anti-caching headers.
  1290. ; http://php.net/session.cache-limiter
  1291. session.cache_limiter = nocache
  1292. ; Document expires after n minutes.
  1293. ; http://php.net/session.cache-expire
  1294. session.cache_expire = 180
  1295. ; trans sid support is disabled by default.
  1296. ; Use of trans sid may risk your users' security.
  1297. ; Use this option with caution.
  1298. ; - User may send URL contains active session ID
  1299. ; to other person via. email/irc/etc.
  1300. ; - URL that contains active session ID may be stored
  1301. ; in publicly accessible computer.
  1302. ; - User may access your site with the same session ID
  1303. ; always using URL stored in browser's history or bookmarks.
  1304. ; http://php.net/session.use-trans-sid
  1305. session.use_trans_sid = 0
  1306. ; Select a hash function for use in generating session ids.
  1307. ; Possible Values
  1308. ; 0 (MD5 128 bits)
  1309. ; 1 (SHA-1 160 bits)
  1310. ; This option may also be set to the name of any hash function supported by
  1311. ; the hash extension. A list of available hashes is returned by the hash_algos()
  1312. ; function.
  1313. ; http://php.net/session.hash-function
  1314. session.hash_function = 0
  1315. ; Define how many bits are stored in each character when converting
  1316. ; the binary hash data to something readable.
  1317. ; Possible values:
  1318. ; 4 (4 bits: 0-9, a-f)
  1319. ; 5 (5 bits: 0-9, a-v)
  1320. ; 6 (6 bits: 0-9, a-z, A-Z, "-", ",")
  1321. ; Default Value: 4
  1322. ; Development Value: 5
  1323. ; Production Value: 5
  1324. ; http://php.net/session.hash-bits-per-character
  1325. session.hash_bits_per_character = 5
  1326. ; The URL rewriter will look for URLs in a defined set of HTML tags.
  1327. ; form/fieldset are special; if you include them here, the rewriter will
  1328. ; add a hidden <input> field with the info which is otherwise appended
  1329. ; to URLs. If you want XHTML conformity, remove the form entry.
  1330. ; Note that all valid entries require a "=", even if no value follows.
  1331. ; Default Value: "a=href,area=href,frame=src,form=,fieldset="
  1332. ; Development Value: "a=href,area=href,frame=src,input=src,form=fakeentry"
  1333. ; Production Value: "a=href,area=href,frame=src,input=src,form=fakeentry"
  1334. ; http://php.net/url-rewriter.tags
  1335. url_rewriter.tags = "a=href,area=href,frame=src,input=src,form=fakeentry"
  1336. ; Enable upload progress tracking in $_SESSION
  1337. ; Default Value: On
  1338. ; Development Value: On
  1339. ; Production Value: On
  1340. ; http://php.net/session.upload-progress.enabled
  1341. ;session.upload_progress.enabled = On
  1342. ; Cleanup the progress information as soon as all POST data has been read
  1343. ; (i.e. upload completed).
  1344. ; Default Value: On
  1345. ; Development Value: On
  1346. ; Production Value: On
  1347. ; http://php.net/session.upload-progress.cleanup
  1348. ;session.upload_progress.cleanup = On
  1349. ; A prefix used for the upload progress key in $_SESSION
  1350. ; Default Value: "upload_progress_"
  1351. ; Development Value: "upload_progress_"
  1352. ; Production Value: "upload_progress_"
  1353. ; http://php.net/session.upload-progress.prefix
  1354. ;session.upload_progress.prefix = "upload_progress_"
  1355. ; The index name (concatenated with the prefix) in $_SESSION
  1356. ; containing the upload progress information
  1357. ; Default Value: "PHP_SESSION_UPLOAD_PROGRESS"
  1358. ; Development Value: "PHP_SESSION_UPLOAD_PROGRESS"
  1359. ; Production Value: "PHP_SESSION_UPLOAD_PROGRESS"
  1360. ; http://php.net/session.upload-progress.name
  1361. ;session.upload_progress.name = "PHP_SESSION_UPLOAD_PROGRESS"
  1362. ; How frequently the upload progress should be updated.
  1363. ; Given either in percentages (per-file), or in bytes
  1364. ; Default Value: "1%"
  1365. ; Development Value: "1%"
  1366. ; Production Value: "1%"
  1367. ; http://php.net/session.upload-progress.freq
  1368. ;session.upload_progress.freq = "1%"
  1369. ; The minimum delay between updates, in seconds
  1370. ; Default Value: 1
  1371. ; Development Value: 1
  1372. ; Production Value: 1
  1373. ; http://php.net/session.upload-progress.min-freq
  1374. ;session.upload_progress.min_freq = "1"
  1375. [MSSQL]
  1376. ; Allow or prevent persistent links.
  1377. mssql.allow_persistent = On
  1378. ; Maximum number of persistent links. -1 means no limit.
  1379. mssql.max_persistent = -1
  1380. ; Maximum number of links (persistent+non persistent). -1 means no limit.
  1381. mssql.max_links = -1
  1382. ; Minimum error severity to display.
  1383. mssql.min_error_severity = 10
  1384. ; Minimum message severity to display.
  1385. mssql.min_message_severity = 10
  1386. ; Compatibility mode with old versions of PHP 3.0.
  1387. mssql.compatibility_mode = Off
  1388. ; Connect timeout
  1389. ;mssql.connect_timeout = 5
  1390. ; Query timeout
  1391. ;mssql.timeout = 60
  1392. ; Valid range 0 - 2147483647. Default = 4096.
  1393. ;mssql.textlimit = 4096
  1394. ; Valid range 0 - 2147483647. Default = 4096.
  1395. ;mssql.textsize = 4096
  1396. ; Limits the number of records in each batch. 0 = all records in one batch.
  1397. ;mssql.batchsize = 0
  1398. ; Specify how datetime and datetim4 columns are returned
  1399. ; On => Returns data converted to SQL server settings
  1400. ; Off => Returns values as YYYY-MM-DD hh:mm:ss
  1401. ;mssql.datetimeconvert = On
  1402. ; Use NT authentication when connecting to the server
  1403. mssql.secure_connection = Off
  1404. ; Specify max number of processes. -1 = library default
  1405. ; msdlib defaults to 25
  1406. ; FreeTDS defaults to 4096
  1407. ;mssql.max_procs = -1
  1408. ; Specify client character set.
  1409. ; If empty or not set the client charset from freetds.conf is used
  1410. ; This is only used when compiled with FreeTDS
  1411. ;mssql.charset = "ISO-8859-1"
  1412. [Assertion]
  1413. ; Assert(expr); active by default.
  1414. ; http://php.net/assert.active
  1415. ;assert.active = On
  1416. ; Issue a PHP warning for each failed assertion.
  1417. ; http://php.net/assert.warning
  1418. ;assert.warning = On
  1419. ; Don't bail out by default.
  1420. ; http://php.net/assert.bail
  1421. ;assert.bail = Off
  1422. ; User-function to be called if an assertion fails.
  1423. ; http://php.net/assert.callback
  1424. ;assert.callback = 0
  1425. ; Eval the expression with current error_reporting(). Set to true if you want
  1426. ; error_reporting(0) around the eval().
  1427. ; http://php.net/assert.quiet-eval
  1428. ;assert.quiet_eval = 0
  1429. [COM]
  1430. ; path to a file containing GUIDs, IIDs or filenames of files with TypeLibs
  1431. ; http://php.net/com.typelib-file
  1432. ;com.typelib_file =
  1433. ; allow Distributed-COM calls
  1434. ; http://php.net/com.allow-dcom
  1435. ;com.allow_dcom = true
  1436. ; autoregister constants of a components typlib on com_load()
  1437. ; http://php.net/com.autoregister-typelib
  1438. ;com.autoregister_typelib = true
  1439. ; register constants casesensitive
  1440. ; http://php.net/com.autoregister-casesensitive
  1441. ;com.autoregister_casesensitive = false
  1442. ; show warnings on duplicate constant registrations
  1443. ; http://php.net/com.autoregister-verbose
  1444. ;com.autoregister_verbose = true
  1445. ; The default character set code-page to use when passing strings to and from COM objects.
  1446. ; Default: system ANSI code page
  1447. ;com.code_page=
  1448. [mbstring]
  1449. ; language for internal character representation.
  1450. ; This affects mb_send_mail() and mbstrig.detect_order.
  1451. ; http://php.net/mbstring.language
  1452. ;mbstring.language = Japanese
  1453. ; Use of this INI entry is deprecated, use global internal_encoding instead.
  1454. ; internal/script encoding.
  1455. ; Some encoding cannot work as internal encoding. (e.g. SJIS, BIG5, ISO-2022-*)
  1456. ; If empty, default_charset or internal_encoding or iconv.internal_encoding is used.
  1457. ; The precedence is: default_charset < internal_encoding < iconv.internal_encoding
  1458. ;mbstring.internal_encoding =
  1459. ; Use of this INI entry is deprecated, use global input_encoding instead.
  1460. ; http input encoding.
  1461. ; mbstring.encoding_traslation = On is needed to use this setting.
  1462. ; If empty, default_charset or input_encoding or mbstring.input is used.
  1463. ; The precedence is: default_charset < intput_encoding < mbsting.http_input
  1464. ; http://php.net/mbstring.http-input
  1465. ;mbstring.http_input =
  1466. ; Use of this INI entry is deprecated, use global output_encoding instead.
  1467. ; http output encoding.
  1468. ; mb_output_handler must be registered as output buffer to function.
  1469. ; If empty, default_charset or output_encoding or mbstring.http_output is used.
  1470. ; The precedence is: default_charset < output_encoding < mbstring.http_output
  1471. ; To use an output encoding conversion, mbstring's output handler must be set
  1472. ; otherwise output encoding conversion cannot be performed.
  1473. ; http://php.net/mbstring.http-output
  1474. ;mbstring.http_output =
  1475. ; enable automatic encoding translation according to
  1476. ; mbstring.internal_encoding setting. Input chars are
  1477. ; converted to internal encoding by setting this to On.
  1478. ; Note: Do _not_ use automatic encoding translation for
  1479. ; portable libs/applications.
  1480. ; http://php.net/mbstring.encoding-translation
  1481. ;mbstring.encoding_translation = Off
  1482. ; automatic encoding detection order.
  1483. ; "auto" detect order is changed according to mbstring.language
  1484. ; http://php.net/mbstring.detect-order
  1485. ;mbstring.detect_order = auto
  1486. ; substitute_character used when character cannot be converted
  1487. ; one from another
  1488. ; http://php.net/mbstring.substitute-character
  1489. ;mbstring.substitute_character = none
  1490. ; overload(replace) single byte functions by mbstring functions.
  1491. ; mail(), ereg(), etc are overloaded by mb_send_mail(), mb_ereg(),
  1492. ; etc. Possible values are 0,1,2,4 or combination of them.
  1493. ; For example, 7 for overload everything.
  1494. ; 0: No overload
  1495. ; 1: Overload mail() function
  1496. ; 2: Overload str*() functions
  1497. ; 4: Overload ereg*() functions
  1498. ; http://php.net/mbstring.func-overload
  1499. ;mbstring.func_overload = 0
  1500. ; enable strict encoding detection.
  1501. ; Default: Off
  1502. ;mbstring.strict_detection = On
  1503. ; This directive specifies the regex pattern of content types for which mb_output_handler()
  1504. ; is activated.
  1505. ; Default: mbstring.http_output_conv_mimetype=^(text/|application/xhtml\+xml)
  1506. ;mbstring.http_output_conv_mimetype=
  1507. [gd]
  1508. ; Tell the jpeg decode to ignore warnings and try to create
  1509. ; a gd image. The warning will then be displayed as notices
  1510. ; disabled by default
  1511. ; http://php.net/gd.jpeg-ignore-warning
  1512. ;gd.jpeg_ignore_warning = 0
  1513. [exif]
  1514. ; Exif UNICODE user comments are handled as UCS-2BE/UCS-2LE and JIS as JIS.
  1515. ; With mbstring support this will automatically be converted into the encoding
  1516. ; given by corresponding encode setting. When empty mbstring.internal_encoding
  1517. ; is used. For the decode settings you can distinguish between motorola and
  1518. ; intel byte order. A decode setting cannot be empty.
  1519. ; http://php.net/exif.encode-unicode
  1520. ;exif.encode_unicode = ISO-8859-15
  1521. ; http://php.net/exif.decode-unicode-motorola
  1522. ;exif.decode_unicode_motorola = UCS-2BE
  1523. ; http://php.net/exif.decode-unicode-intel
  1524. ;exif.decode_unicode_intel = UCS-2LE
  1525. ; http://php.net/exif.encode-jis
  1526. ;exif.encode_jis =
  1527. ; http://php.net/exif.decode-jis-motorola
  1528. ;exif.decode_jis_motorola = JIS
  1529. ; http://php.net/exif.decode-jis-intel
  1530. ;exif.decode_jis_intel = JIS
  1531. [Tidy]
  1532. ; The path to a default tidy configuration file to use when using tidy
  1533. ; http://php.net/tidy.default-config
  1534. ;tidy.default_config = /usr/local/lib/php/default.tcfg
  1535. ; Should tidy clean and repair output automatically?
  1536. ; WARNING: Do not use this option if you are generating non-html content
  1537. ; such as dynamic images
  1538. ; http://php.net/tidy.clean-output
  1539. tidy.clean_output = Off
  1540. [soap]
  1541. ; Enables or disables WSDL caching feature.
  1542. ; http://php.net/soap.wsdl-cache-enabled
  1543. soap.wsdl_cache_enabled=1
  1544. ; Sets the directory name where SOAP extension will put cache files.
  1545. ; http://php.net/soap.wsdl-cache-dir
  1546. soap.wsdl_cache_dir="/tmp"
  1547. ; (time to live) Sets the number of second while cached file will be used
  1548. ; instead of original one.
  1549. ; http://php.net/soap.wsdl-cache-ttl
  1550. soap.wsdl_cache_ttl=86400
  1551. ; Sets the size of the cache limit. (Max. number of WSDL files to cache)
  1552. soap.wsdl_cache_limit = 5
  1553. [sysvshm]
  1554. ; A default size of the shared memory segment
  1555. ;sysvshm.init_mem = 10000
  1556. [ldap]
  1557. ; Sets the maximum number of open links or -1 for unlimited.
  1558. ldap.max_links = -1
  1559. [mcrypt]
  1560. ; For more information about mcrypt settings see http://php.net/mcrypt-module-open
  1561. ; Directory where to load mcrypt algorithms
  1562. ; Default: Compiled in into libmcrypt (usually /usr/local/lib/libmcrypt)
  1563. ;mcrypt.algorithms_dir=
  1564. ; Directory where to load mcrypt modes
  1565. ; Default: Compiled in into libmcrypt (usually /usr/local/lib/libmcrypt)
  1566. ;mcrypt.modes_dir=
  1567. [dba]
  1568. ;dba.default_handler=
  1569. [opcache]
  1570. ; Determines if Zend OPCache is enabled
  1571. ;opcache.enable=0
  1572. ; Determines if Zend OPCache is enabled for the CLI version of PHP
  1573. ;opcache.enable_cli=0
  1574. ; The OPcache shared memory storage size.
  1575. ;opcache.memory_consumption=64
  1576. ; The amount of memory for interned strings in Mbytes.
  1577. ;opcache.interned_strings_buffer=4
  1578. ; The maximum number of keys (scripts) in the OPcache hash table.
  1579. ; Only numbers between 200 and 100000 are allowed.
  1580. ;opcache.max_accelerated_files=2000
  1581. ; The maximum percentage of "wasted" memory until a restart is scheduled.
  1582. ;opcache.max_wasted_percentage=5
  1583. ; When this directive is enabled, the OPcache appends the current working
  1584. ; directory to the script key, thus eliminating possible collisions between
  1585. ; files with the same name (basename). Disabling the directive improves
  1586. ; performance, but may break existing applications.
  1587. ;opcache.use_cwd=1
  1588. ; When disabled, you must reset the OPcache manually or restart the
  1589. ; webserver for changes to the filesystem to take effect.
  1590. ;opcache.validate_timestamps=1
  1591. ; How often (in seconds) to check file timestamps for changes to the shared
  1592. ; memory storage allocation. ("1" means validate once per second, but only
  1593. ; once per request. "0" means always validate)
  1594. ;opcache.revalidate_freq=2
  1595. ; Enables or disables file search in include_path optimization
  1596. ;opcache.revalidate_path=0
  1597. ; If disabled, all PHPDoc comments are dropped from the code to reduce the
  1598. ; size of the optimized code.
  1599. ;opcache.save_comments=1
  1600. ; If disabled, PHPDoc comments are not loaded from SHM, so "Doc Comments"
  1601. ; may be always stored (save_comments=1), but not loaded by applications
  1602. ; that don't need them anyway.
  1603. ;opcache.load_comments=1
  1604. ; If enabled, a fast shutdown sequence is used for the accelerated code
  1605. ;opcache.fast_shutdown=0
  1606. ; Allow file existence override (file_exists, etc.) performance feature.
  1607. ;opcache.enable_file_override=0
  1608. ; A bitmask, where each bit enables or disables the appropriate OPcache
  1609. ; passes
  1610. ;opcache.optimization_level=0xffffffff
  1611. ;opcache.inherited_hack=1
  1612. ;opcache.dups_fix=0
  1613. ; The location of the OPcache blacklist file (wildcards allowed).
  1614. ; Each OPcache blacklist file is a text file that holds the names of files
  1615. ; that should not be accelerated. The file format is to add each filename
  1616. ; to a new line. The filename may be a full path or just a file prefix
  1617. ; (i.e., /var/www/x blacklists all the files and directories in /var/www
  1618. ; that start with 'x'). Line starting with a ; are ignored (comments).
  1619. ;opcache.blacklist_filename=
  1620. ; Allows exclusion of large files from being cached. By default all files
  1621. ; are cached.
  1622. ;opcache.max_file_size=0
  1623. ; Check the cache checksum each N requests.
  1624. ; The default value of "0" means that the checks are disabled.
  1625. ;opcache.consistency_checks=0
  1626. ; How long to wait (in seconds) for a scheduled restart to begin if the cache
  1627. ; is not being accessed.
  1628. ;opcache.force_restart_timeout=180
  1629. ; OPcache error_log file name. Empty string assumes "stderr".
  1630. ;opcache.error_log=
  1631. ; All OPcache errors go to the Web server log.
  1632. ; By default, only fatal errors (level 0) or errors (level 1) are logged.
  1633. ; You can also enable warnings (level 2), info messages (level 3) or
  1634. ; debug messages (level 4).
  1635. ;opcache.log_verbosity_level=1
  1636. ; Preferred Shared Memory back-end. Leave empty and let the system decide.
  1637. ;opcache.preferred_memory_model=
  1638. ; Protect the shared memory from unexpected writing during script execution.
  1639. ; Useful for internal debugging only.
  1640. ;opcache.protect_memory=0
  1641. ; Validate cached file permissions.
  1642. ; opcache.validate_permission=0
  1643. ; Prevent name collisions in chroot'ed environment.
  1644. ; opcache.validate_root=0
  1645. [curl]
  1646. ; A default value for the CURLOPT_CAINFO option. This is required to be an
  1647. ; absolute path.
  1648. ;curl.cainfo =
  1649. [openssl]
  1650. ; The location of a Certificate Authority (CA) file on the local filesystem
  1651. ; to use when verifying the identity of SSL/TLS peers. Most users should
  1652. ; not specify a value for this directive as PHP will attempt to use the
  1653. ; OS-managed cert stores in its absence. If specified, this value may still
  1654. ; be overridden on a per-stream basis via the "cafile" SSL stream context
  1655. ; option.
  1656. ;openssl.cafile=
  1657. ; If openssl.cafile is not specified or if the CA file is not found, the
  1658. ; directory pointed to by openssl.capath is searched for a suitable
  1659. ; certificate. This value must be a correctly hashed certificate directory.
  1660. ; Most users should not specify a value for this directive as PHP will
  1661. ; attempt to use the OS-managed cert stores in its absence. If specified,
  1662. ; this value may still be overridden on a per-stream basis via the "capath"
  1663. ; SSL stream context option.
  1664. ;openssl.capath=
  1665. ; Local Variables:
  1666. ; tab-width: 4
  1667. ; End:
  • 编写Docker-Compose文件
version: "3.3"

services:
  nginx:
    hostname: nginx
    build: 
      context: ./nginx
      dockerfile: Dockerfile
    # expose:
    #   - "80"
    ports:
      - "80:80"
    restart: always
    links:
      - "mysql"
      - "php:php-cgi"
    volumes:
      # - /data/container/web:/usr/local/nginx/html
      - ./wwwroot:/usr/local/nginx/html
    depends_on:
      - mysql
      - php

  php:
    hostname: php
    build: ./php
    # ports:
    #   - "9000:9000"
    restart: always
    links:
      - mysql:mysql-db
    volumes:
      # - /data/container/web:/usr/local/nginx/html
      - ./wwwroot:/usr/local/nginx/html

  mysql:
    hostname: mysql
    image: mysql:5.6
    restart: always
    ports:
      - "3306:3306"
    environment:
      MYSQL_ROOT_PASSWORD: 123456
      MYSQL_USER: user
      MYSQL_PASSWORD: 123456
    volumes:
      - ./mysql/conf:/etc/mysql/conf.d
      - ./mysql/data:/var/lib/mysql

Docker-Compose项目的文件列表

$ tree -p
.
├── [-rw-r--r--]  docker-compose.yml
├── [drwxr-xr-x]  mysql
│   ├── [drwxr-xr-x]  conf
│   │   └── [-rw-r--r--]  my.cnf
│   └── [-rw-r--r--]  my.cnf
├── [drwxr-xr-x]  nginx
│   ├── [-rw-r--r--]  Dockerfile
│   └── [-rw-r--r--]  nginx.conf
└── [drwxr-xr-x]  php
    ├── [-rw-r--r--]  Dockerfile
    └── [-rw-r--r--]  php.ini

4 directories, 7 files

# 运行docker-compose命令执行构建
$ docker-compose up -d
# 查看docker-compose的运行进程
$ docker-compose ps 
NAME                   COMMAND                  SERVICE             STATUS              PORTS
compose-lnmp-mysql-1   "docker-entrypoint.s…"   mysql               running             0.0.0.0:3306->3306/tcp, :::3306->3306/tcp
compose-lnmp-nginx-1   "/usr/local/nginx/sb…"   nginx               running             0.0.0.0:80->80/tcp, :::80->80/tcp
compose-lnmp-php-1     "/bin/sh -c '/etc/in…"   php                 running             9000/tcp

# 访问PHP页面
$ echo "<?php phpinfo()?>" > wwwroot/test.php
$ curl 127.0.0.1/test.php

01 Docker 进阶 %26 Kubernetes 入门 - 图2

1.6.2 一键部署 Nginx 反向代理 Tomcat 集群

  • MySQL 部署
[mysqld]
user = mysql
port = 3306
datadir = /var/lib/mysql
socket  = /var/lib/mysql/mysql.sock
pid-file  = /var/run/mysql/mysql.pid
log_error = /var/log/mysql/error.log
character-set-server = utf8mb4
character-set-client = utf8mb4
max_connections = 3600
  • Nginx 部署

Dockerfile

FROM centos:6

MAINTAINER <zhongzhiwei zhongzhiwei@kubesphere.io>

# 获取最新Yum源信息 & 下载相应软件
RUN curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-vault-6.10.repo && \
    yum install -y gcc gcc-c++ make openssl-devel pcre-devel
ADD http://nginx.org/download/nginx-1.12.2.tar.gz /tmp
# 需要将nginx-1.12.2.tar.gz存放在Dockerfile同级目录下
# ADD nginx-1.12.2.tar.gz /tmp

RUN cd /tmp/nginx-1.12.2 && ./configure --prefix=/usr/local/nginx && make -j 2 && make install
RUN rm -f /usr/local/nginx/conf/nginx.conf 
COPY ./nginx.conf /usr/local/nginx/conf

EXPOSE 80
CMD ["/usr/local/nginx/sbin/nginx", "-g", "daemon off;"]

Nginx配置文件 nginx.conf

user  root; 
worker_processes  auto; 

error_log  logs/error.log  info;

pid        logs/nginx.pid; 

events {
    use epoll; 
}

http {

    include       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 logs/access.log main;
    sendfile        on;
    keepalive_timeout  65;

    upstream www.example.com {
        #ip_hash;
        server tomcat01:8080;
          server tomcat02:8080;
          server tomcat03:8080;
    }

    server {
        listen 80;
        server_name localhost;

          location / {
              proxy_pass http://www.example.com;
          }

        location ~ \.(html|css|js|jpg|png|gif)$ {
            root /opt/webapps/ROOT;
        }
    }
}
  • Tomcat 部署

Dockerfile

FROM centos:6

MAINTAINER <zhongzhiwei zhongzhiwei@kubesphere.io> 

# 获取最新Yum源信息 & 下载相应软件
RUN curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-vault-6.10.repo

ADD jdk-8u45-linux-x64.tar.gz /usr/local
ENV JAVA_HOME /usr/local/jdk1.8.0_45

ADD apache-tomcat-8.5.83.tar.gz /usr/local
COPY server.xml /usr/local/apache-tomcat-8.5.83/conf

EXPOSE 8080
ENTRYPOINT ["/usr/local/apache-tomcat-8.5.83/bin/catalina.sh", "run"]

server.xml 配置文件

<?xml version="1.0" encoding="UTF-8"?>
<Server port="8005" shutdown="SHUTDOWN">
  <Listener className="org.apache.catalina.startup.VersionLoggerListener" />
  <!-- Security listener. Documentation at /docs/config/listeners.html
  <Listener className="org.apache.catalina.security.SecurityListener" />
  -->
  <!-- APR library loader. Documentation at /docs/apr.html -->
  <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />
  <!-- Prevent memory leaks due to use of particular java/javax APIs-->
  <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />
  <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
  <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />

  <!-- Global JNDI resources
       Documentation at /docs/jndi-resources-howto.html
  -->
  <GlobalNamingResources>
    <!-- Editable user database that can also be used by
         UserDatabaseRealm to authenticate users
    -->
    <Resource name="UserDatabase" auth="Container"
              type="org.apache.catalina.UserDatabase"
              description="User database that can be updated and saved"
              factory="org.apache.catalina.users.MemoryUserDatabaseFactory"
              pathname="conf/tomcat-users.xml" />
  </GlobalNamingResources>

  <!-- A "Service" is a collection of one or more "Connectors" that share
       a single "Container" Note:  A "Service" is not itself a "Container",
       so you may not define subcomponents such as "Valves" at this level.
       Documentation at /docs/config/service.html
   -->
  <Service name="Catalina">

    <!--The connectors can use a shared executor, you can define one or more named thread pools-->
    <!--
    <Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
        maxThreads="150" minSpareThreads="4"/>
    -->


    <!-- A "Connector" represents an endpoint by which requests are received
         and responses are returned. Documentation at :
         Java HTTP Connector: /docs/config/http.html
         Java AJP  Connector: /docs/config/ajp.html
         APR (HTTP/AJP) Connector: /docs/apr.html
         Define a non-SSL/TLS HTTP/1.1 Connector on port 8080
    -->
    <Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
    <!-- A "Connector" using the shared thread pool-->
    <!--
    <Connector executor="tomcatThreadPool"
               port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
    -->
    <!-- Define an SSL/TLS HTTP/1.1 Connector on port 8443
         This connector uses the NIO implementation. The default
         SSLImplementation will depend on the presence of the APR/native
         library and the useOpenSSL attribute of the AprLifecycleListener.
         Either JSSE or OpenSSL style configuration may be used regardless of
         the SSLImplementation selected. JSSE style configuration is used below.
    -->
    <!--
    <Connector port="8443" protocol="org.apache.coyote.http11.Http11NioProtocol"
               maxThreads="150" SSLEnabled="true">
        <SSLHostConfig>
            <Certificate certificateKeystoreFile="conf/localhost-rsa.jks"
                         type="RSA" />
        </SSLHostConfig>
    </Connector>
    -->
    <!-- Define an SSL/TLS HTTP/1.1 Connector on port 8443 with HTTP/2
         This connector uses the APR/native implementation which always uses
         OpenSSL for TLS.
         Either JSSE or OpenSSL style configuration may be used. OpenSSL style
         configuration is used below.
    -->
    <!--
    <Connector port="8443" protocol="org.apache.coyote.http11.Http11AprProtocol"
               maxThreads="150" SSLEnabled="true" >
        <UpgradeProtocol className="org.apache.coyote.http2.Http2Protocol" />
        <SSLHostConfig>
            <Certificate certificateKeyFile="conf/localhost-rsa-key.pem"
                         certificateFile="conf/localhost-rsa-cert.pem"
                         certificateChainFile="conf/localhost-rsa-chain.pem"
                         type="RSA" />
        </SSLHostConfig>
    </Connector>
    -->

    <!-- Define an AJP 1.3 Connector on port 8009 -->
    <!--
    <Connector protocol="AJP/1.3"
               address="::1"
               port="8009"
               redirectPort="8443" />
    -->

    <!-- An Engine represents the entry point (within Catalina) that processes
         every request.  The Engine implementation for Tomcat stand alone
         analyzes the HTTP headers included with the request, and passes them
         on to the appropriate Host (virtual host).
         Documentation at /docs/config/engine.html -->

    <!-- You should set jvmRoute to support load-balancing via AJP ie :
    <Engine name="Catalina" defaultHost="localhost" jvmRoute="jvm1">
    -->
    <Engine name="Catalina" defaultHost="localhost">

      <!--For clustering, please take a look at documentation at:
          /docs/cluster-howto.html  (simple how to)
          /docs/config/cluster.html (reference documentation) -->
      <!--
      <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>
      -->

      <!-- Use the LockOutRealm to prevent attempts to guess user passwords
           via a brute-force attack -->
      <Realm className="org.apache.catalina.realm.LockOutRealm">
        <!-- This Realm uses the UserDatabase configured in the global JNDI
             resources under the key "UserDatabase".  Any edits
             that are performed against this UserDatabase are immediately
             available for use by the Realm.  -->
        <Realm className="org.apache.catalina.realm.UserDatabaseRealm"
               resourceName="UserDatabase"/>
      </Realm>

      <Host name="localhost"  appBase="webapps"
            unpackWARs="true" autoDeploy="true">

        <!-- SingleSignOn valve, share authentication between web applications
             Documentation at: /docs/config/valve.html -->
        <!--
        <Valve className="org.apache.catalina.authenticator.SingleSignOn" />
        -->

        <!-- Access log processes all example.
             Documentation at: /docs/config/valve.html
             Note: The pattern used is equivalent to using pattern="common" -->
        <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix="localhost_access_log" suffix=".txt"
               pattern="%h %l %u %t &quot;%r&quot; %s %b" />

      </Host>
    </Engine>
  </Service>
</Server>
  • Docker-Compose.yml 文件
version: '3'
services:
  nginx:
    hostname: nginx
    build:
      context: ./nginx
      dockerfile: Dockerfile
    ports:
      - 80:80
    links:
      - tomcat01:tomcat01
      - tomcat02:tomcat02
      - tomcat03:tomcat03
    volumes:
      - ./webapps:/opt/webapps
    depends_on:
      - mysql
      - tomcat01
      - tomcat02
      - tomcat03

  tomcat01:
    hostname: tomcat01
    build: ./tomcat
    links:
      - mysql:mysql-db
    volumes:
      - ./webapps:/usr/local/apache-tomcat-8.5.83/webapps

  tomcat02:
    hostname: tomcat02
    build: ./tomcat
    links:
      - mysql:mysql-db
    volumes:
      - ./webapps:/usr/local/apache-tomcat-8.5.83/webapps

  tomcat03:
    hostname: tomcat03
    build: ./tomcat
    links:
      - mysql:mysql-db
    volumes:
      - ./webapps:/usr/local/apache-tomcat-8.5.83/webapps

  mysql:
    hostname: mysql
    image: mysql:5.6
    ports:
      - 3306:3306
    volumes:
      - ./mysql/conf:/etc/mysql/conf.d
      - ./mysql/data:/var/lib/mysql
    environment:
      MYSQL_ROOT_PASSWORD: 123456
      MYSQL_DATABASE: db
      MYSQL_USER: user
      MYSQL_PASSWORD: 123456
    privileged: true

Docker-Compose 目录结构:

$ mkdir -pv compose-nginx-tomcat ; cd compose-nginx-tomcat
$ mkdir -pv nginx mysql/{conf,data} tomcat webapps/ROOT
$ echo "Java Page ......" > webapps/ROOT/index.jsp

# 查看项目的目录结构
$ tree 
tree  -p
.
├── [-rw-r--r--]  docker-compose.yml
├── [drwxr-xr-x]  mysql
│   ├── [drwxr-xr-x]  conf
│   │   └── [-rw-r--r--]  my.cnf
│   └── [drwxr-xr-x]  data
├── [drwxr-xr-x]  nginx
│   ├── [-rw-r--r--]  Dockerfile
│   └── [-rw-r--r--]  nginx.conf
├── [drwxr-xr-x]  tomcat
│   ├── [-rw-r--r--]  apache-tomcat-8.5.83.tar.gz
│   ├── [-rw-r--r--]  Dockerfile
│   ├── [-rw-r--r--]  jdk-8u45-linux-x64.tar.gz
│   └── [-rw-r--r--]  server.xml
└── [drwxr-xr-x]  webapps
    └── [drwxr-xr-x]  ROOT
        └── [-rw-r--r--]  index.jsp

7 directories, 9 files

$ docker-compose up -d
$ docker-compose ps 
NAME                              COMMAND                  SERVICE             STATUS              PORTS
compose-nginx-tomcat-mysql-1      "docker-entrypoint.s…"   mysql               running             0.0.0.0:3306->3306/tcp, :::3306->3306/tcp
compose-nginx-tomcat-nginx-1      "/usr/local/nginx/sb…"   nginx               running             0.0.0.0:80->80/tcp, :::80->80/tcp
compose-nginx-tomcat-tomcat01-1   "/usr/local/apache-t…"   tomcat01            running             8080/tcp
compose-nginx-tomcat-tomcat02-1   "/usr/local/apache-t…"   tomcat02            running             8080/tcp
compose-nginx-tomcat-tomcat03-1   "/usr/local/apache-t…"   tomcat03            running             8080/tcp

# 查看Docker-compose项目的各容器的日志
$ docker-compose logs

# 访问页面
$ curl 110.41.20.249
Java Page ......

添加内容显示后端代理的地址

# $ docker exec -it compose_nginx_tomcat_nginx_1 bash
$ vim nginx/nginx.conf
user  root; 
worker_processes  auto; 

error_log  logs/error.log  info;

pid        logs/nginx.pid; 

events {
    use epoll; 
}

http {

    include       mime.types;
    default_type  application/octet-stream;

    log_format  main '$upstream_addr $remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log logs/access.log main;
    sendfile        on;
    keepalive_timeout  65;

    upstream www.example.com {
        #ip_hash;
        server tomcat01:8080;
            server tomcat02:8080;
            server tomcat03:8080;
    }

    server {
        listen 80;
        server_name localhost;

              location / {
                  proxy_pass http://www.example.com;
              }

        location ~ \.(html|css|js|jpg|png|gif)$ {
            root /opt/webapps/ROOT;
        }
    }
}

01 Docker 进阶 %26 Kubernetes 入门 - 图3

# 修改后需要退出容器使用docker-compose restart重启才能使配置生效,在容器内重启nginx不生效
docker-compose restart

# 访问页面
$ curl 110.41.20.249
Java Page ......

# 停止运行的容器
$ docker-compose stop

1.6.3 一键部署多节点爬虫程序

$ mkdir -pv compose-crawler/centos && cd compose-crawler/
  • CentOS 部署目录下的文件内容

Dockerfile 文件内容

FROM centos:6

MAINTAINER <zhongzhiwei zhongzhiwei@kubesphere.io>

COPY curl.sh /
CMD [ "/bin/bash","/curl.sh" ]

curl.sh 文件内容

#!/bin/bash
for i in {1..100} ; do
    curl http://www.baidu.com -o /dev/null
    sleep 1
done
  • Docker-Compose.yml 文件内容
version: '3'

services:
  curl-test:
    build: 
      context: ./centos
      dockerfile: Dockerfile

查看项目的目录结构

$ tree -p
.
├── [drwxr-xr-x]  centos
│   ├── [-rw-r--r--]  curl.sh
│   └── [-rw-r--r--]  Dockerfile
└── [-rw-r--r--]  docker-compose.yml

1 directory, 3 files

$ docker-compose up -d
$ docker-compose ps 
NAME                          COMMAND                SERVICE             STATUS              PORTS
compose-crawler-curl-test-1   "/bin/bash /curl.sh"   curl-test           running

# 查看docker-compose的日志
$ docker-compose logs -f
compose-crawler-curl-test-1  |   % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
compose-crawler-curl-test-1  |                                  Dload  Upload   Total   Spent    Left  Speed
103  2381  103  2381    0     0  70985      0 --:--:-- --:--:-- --:--:-- 99208

# 设置副本数为3
$ docker-compose up --scale curl-test=3
$ docker-compose ps 
NAME                          COMMAND                SERVICE             STATUS              PORTS
compose-crawler-curl-test-1   "/bin/bash /curl.sh"   curl-test           running             
compose-crawler-curl-test-2   "/bin/bash /curl.sh"   curl-test           running             
compose-crawler-curl-test-3   "/bin/bash /curl.sh"   curl-test           running

# 设置副本数为10
$ docker-compose up --scale curl-test=10

2 多主机网络

2.1 网络术语概念

2.1.1 基础网络

  • 二层交换技术:工作在OSI七层网络模型的第二层,通过<font style="color:#E8323C;">MAC地址</font>进行<font style="color:#E8323C;">帧转发</font>
  • 三层交换技术:也称为IP交换技术,工作在OSI七层网络模型的第三层,通过<font style="color:#E8323C;">IP地址</font>进行<font style="color:#E8323C;">包转发</font>。它解决了局域网中网段划分之后,网段中子网必须依赖路由器进行管理的局面。
  • 网桥(Bridge):工作在OSI七层网络模型的第二层,根据MAC地址转发,类似于二层交换机。Linux网桥将不同的网络接口连接起来,连接的网络接口可以来自不同的局域网,网桥决定了接收的数据包是转发给同一个局域网内主机还是别的网络上。
  • VLAN ( Virtual Local Area Network,虚拟局域网):在物理网络(通常路由器接口)基础上建立一个或多个逻辑子网,将一个大的广播域切分若干小的广播域。一个VLAN就是一个广播域,VLAN之间通信通过三层路由器来完成。

[ 二层交换机是不隔离广播域的,三层交换机是隔离广播域 ]

2.1.2 Overlay Network

Reference:数据中心网络虚拟化-隧道技术

01 Docker 进阶 %26 Kubernetes 入门 - 图4

Overlay Network:覆盖网络,在基础网络上叠加的一种虚拟网络技术模式,该网络中的主机通过虚拟链路连接起来。

Overlay网络有以下三种实现方式:

VXLAN(Virtual Extensible Local Area Network,虚拟可扩展局域网),通过将物理服务器或虚拟机发出的数据包封装到UDP中,并使用物理网络的IP/MAC作为外层报文头进行封装,然后在IP网络上传输,到达目的地后由隧道端点(点到点的模式)解封装并将数据发送给目标物理服务器或虚拟机,扩展了大规模虚拟机网络通信。 由于VLAN Header头部限制长度是12bit,导致只能分配4095个VLAN,也就是4095个网段,在大规模虚拟网络。VXLAN标准定义Header限制长度24bit,可以支持1600万个VLAN,满足大规模虚拟机网络需求。 VXLAN有以下核心技术组成: + NVE (Network Vritual Endpoint,网络虚拟端点):实现网络虚拟化功能。报文经过NVE封装转换后,NVE间就可基于三层基础网络建立二层虚拟化网络。 + VTEP (VXLAN Tunnel Endpoints,VXLAN隧道端点):封装在NVE中,用于VXLAN报文的封装和解封装。 + VNI (VXLAN Network Identifier,VXLAN网络标识ID):类似于VLAN ID,用于区分VXLAN段,不同的VXLAN段不能直接二层网络通信。 01 Docker 进阶 %26 Kubernetes 入门 - 图5 VXLAN 网络: 01 Docker 进阶 %26 Kubernetes 入门 - 图6 VXlan 的其他类似网络技术: NVGRE(Network Virtual using Ceneric Routing Encapsulation,使用GRE虚拟网络)∶与VXLAN不同的是,NVGRE没有采用标准传输协议(TCP/UDP),而是借助<font style="color:#E8323C;">通用路由封装协议(GRE)</font>。采用24bit标识二层网络分段,与VXLAN一样可以支持1600万个虚拟网络。 STT(Stateless Transport Tunneling,无状态传输隧道):模拟TCP数据格式进行封装,改造了TCP传输机制,不维护TCP状态信息。是在数据中心2层/3层物理网络上创建2层虚拟网络的又一种Overlay技术。在进行数据封装时使用了无状 态的类TCP头(TCP-like Header),因此可以认为其是一种MAC-in-TCP方式。使用类TCP头的好处在于可以利用网卡的一些硬件下放机制来提高系统性能,例如 TSO(TCP Segmentation Offload)和 LRO(Large Receive Offload)。利用TSO技术,我们可以将TCP分片工作下放到网卡。由网卡来完成大包地分片,以及复制MAC、IP、TCP包头等工作。相反,所谓 的LRO技术,即是接收端利用网卡将分片合并成一个大包之后再生成一个中断并发送给操作系统。TSO和LRO的好处是明显的。首先,通过传输大包的方式减 少了系统中断的次数,从而减少中断开销。其次,封装的开销(封装头)可以均摊到多个MTU大小的数据包上,所以数据传输的有效性也可以大幅提升。为了利用 网卡的这种加速特性,STT的封装头模拟了TCP的格式,但是STT并没有维护TCP的连接状态。例如,在使用STT发送数据之前不需要进行三次握手,并 且TCP的拥塞控制机制等等也不会起作用。虽然STT可以利用网卡加速来提升系统性能,但是由于其没有维护TCP的状态信息,所以其也会遇到一些问题。例 如,某些系统中可能会使用一些中间盒(middlebox),但是由于有些中间盒会检查数据流的四层会话状态,所以会导致无状态的STT流无法通过这些中 间盒。当然这个问题,采用MAC-in-IP的NVGRE方案也同样存在。但是对于MAC-in-UDP的VXLAN方案则不是问题。

:::color1 Overlay Network 业内主流的网络模式技术:VXLAN,NVGRE,STT。

:::

2.2 容器跨主机通信主流方案

  1. 桥接宿主机网络
  2. 端口映射
  3. Docker网络驱动
  • Overlay:基于VXLAN封装实现Docker原生Overlay网络
  • Macvlan:Docker主机网卡接口逻辑上分为多个子接口,每个子接口标识一个VLAN。容器接口直接连接Docker主机网卡接口,通过路由策略转发到另一台Docker主机[ 是Docker做了一定的实现,是利用Linux内核的Macvlan的模块 ]
  1. 第三方网络项目
    1. 隧道方案
      1. Flannel:支持UDP和VXLAN封装传输方式
      2. Weave:支持UDP (sleeve模式)和VXLAN(优先fastdp模式
      3. OpenvSwitch:是一种虚拟的二层交换机,支持VXLAN和GRE协议
    2. 路由方案
      1. Calico:支持BGP协议和IPIP隧道。每台宿住主机作为虚拟路由,通过BGP协议实现不同主机容器间通信

2.3 Docker Overlay

2.3.1 部署前提

Docker通过 Overlay 网络驱动程序支持多主机容器网络通信。

要想使用Docker原生Overlay网络,需要满足以下任意条件:

  • Docker运行在Swarm模式
  • 使用键值存储的Docker主机集群

我们这里演示第二种,需要满足以下条件:

  1. 集群中主机连接到键值存储,Docker支持 Consul、Etcd 和 Zookeeper;
  2. 集群中主机运行一个Docker守护进程;
  3. 集群中主机必须具有唯一的主机名,因为键值存储使用主机名来标识集群成员;
  4. 集群中Linux主机内核版本3.12+,支持VXLAN数据包处理,否则可能无法通信。( CentOS 7.9.2009 系统有可能会因为内核版本旧导致实验失败 )

2.3.2 部署

:::color1 推荐使用CentOS 8,Ubuntu 19.04 之上的版本进行部署!以下采用 Ubuntu 20.04 版本进行部署。

:::

节点1/键值存储:10.0.0.100 [ 主机名:kubesphere-master ]

节点2:10.0.0.101 [ 主机名:kubesphere-client ]

  1. 部署 Docker 环境
# step 1: 安装必要的一些系统工具
sudo apt-get update
sudo apt-get -y install apt-transport-https ca-certificates curl software-properties-common

# step 2: 安装GPG证书
curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -

# Step 3: 写入软件源信息
sudo add-apt-repository "deb [arch=amd64] https://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable"

# Step 4: 更新并安装Docker-CE
sudo apt-get -y update
sudo apt-get -y install docker-ce

# 安装指定版本的Docker-CE:
# Step 1: 查找Docker-CE的版本:
# apt-cache madison docker-ce
#   docker-ce | 17.03.1~ce-0~ubuntu-xenial | https://mirrors.aliyun.com/docker-ce/linux/ubuntu xenial/stable amd64 Packages
#   docker-ce | 17.03.0~ce-0~ubuntu-xenial | https://mirrors.aliyun.com/docker-ce/linux/ubuntu xenial/stable amd64 Packages
# Step 2: 安装指定版本的Docker-CE: (VERSION例如上面的17.03.1~ce-0~ubuntu-xenial)
# sudo apt-get -y install docker-ce=[VERSION]

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://po13h3y1.mirror.aliyuncs.com","http://hub-mirror.c.163.com","https://mirror.ccs.tencentyun.com","http://f1361db2.m.daocloud.io"],
  "exec-opts": ["native.cgroupdriver=systemd"],
  "log-driver": "json-file",
  "log-opts": {
    "max-size": "100m"
  },
  "storage-driver": "overlay2"
}
EOF

sudo systemctl daemon-reload && sudo systemctl restart docker
  1. 下载Consul二进制包并启动
$ wget https://releases.hashicorp.com/consul/0.9.2/consul_0.9.2_linux_amd64.zip 
$ apt install -y zip unzip
$ unzip consul_0.9.2_linux_amd64.zip
$ mv consul /usr/bin/consul && chmod +x /usr/bin/consul
$ nohup consul agent -server -bootstrap -ui -data-dir /var/lib/consul -client=10.0.0.100 -bind=10.0.0.100 &> /var/log/consul.log &
$ jobs 
[1]+  Running                 nohup consul agent -server -bootstrap -ui -data-dir /var/lib/consul -client=10.0.0.100 -bind=10.0.0.100 &> /var/log/consul.log &

# 查看日志
$ tail -f /var/log/consul.log
    2022/11/26 05:10:22 [ERR] agent: failed to sync remote state: No cluster leader
==> Newer Consul version available: 1.14.1 (currently running: 0.9.2)
    2022/11/26 05:10:23 [WARN] raft: Heartbeat timeout from "" reached, starting election
    2022/11/26 05:10:23 [INFO] raft: Node at 10.0.0.100:8300 [Candidate] entering Candidate state in term 2
    2022/11/26 05:10:23 [INFO] raft: Election won. Tally: 1
    2022/11/26 05:10:23 [INFO] raft: Node at 10.0.0.100:8300 [Leader] entering Leader state
    2022/11/26 05:10:23 [INFO] consul: cluster leadership acquired
    2022/11/26 05:10:23 [INFO] consul: New leader elected: kubesphere-ubuntu
    2022/11/26 05:10:23 [INFO] consul: member 'kubesphere-ubuntu' joined, marking health alive
    2022/11/26 05:10:24 [INFO] agent: Synced node info

浏览器访问 http://<Master-IP地址>:8500

01 Docker 进阶 %26 Kubernetes 入门 - 图7

两台服务器运行 busybox 容器查看是否可以进行连通性测试

$ docker run -it -d --name busybox-node busybox /bin/sh
# 查看容器的IP地址
$ docker inspect -f "{{.NetworkSettings.Networks.bridge.IPAddress}}" busybox-node
# IP地址相同,两边是无法正常通信的

01 Docker 进阶 %26 Kubernetes 入门 - 图8

01 Docker 进阶 %26 Kubernetes 入门 - 图9

  1. 所有节点配置Docker守护进程连接Consul
# --cluster-advertise 集群通告地址
# kubesphere-master 配置
$ vim /lib/systemd/system/docker.service
[Service]
ExecStart=/usr/bin/dockerd -H tcp://0.0.0.0:2375 -H unix:///var/run/docker.sock --cluster-store consul://10.0.0.100:8500 --cluster-advertise 10.0.0.100:2375

$ systemctl daemon-reload && systemctl restart docker

# kubesphere-client 配置
$ vim /lib/systemd/system/docker.service
[Service]
ExecStart=/usr/bin/dockerd -H tcp://0.0.0.0:2375 -H unix:///var/run/docker.sock --cluster-store consul://10.0.0.100:8500 --cluster-advertise 10.0.0.101:2375

$ systemctl daemon-reload && systemctl restart docker

浏览器访问 http://<Master-IP地址>:8500

01 Docker 进阶 %26 Kubernetes 入门 - 图10

  1. 节点创建overlay网络
$ docker network create -d overlay --subnet "192.168.0.0/24" --gateway "192.168.0.1" multi_host

# 在所有节点就可以查看到该Docker网络
$ docker network ls 
NETWORK ID     NAME              DRIVER    SCOPE
79961fd3c47c   bridge            bridge    local
e99aef116287   docker_gwbridge   bridge    local
91a9e5257fb4   host              host      local
1633d3a2b72f   multi_host        overlay   global
0279a9dbc65d   none              null      local

# 查看网络的详细信息显示
$ docker network inspect multi_host 
[
    {
        "Name": "multi_host",
        "Id": "1633d3a2b72f807649d588ea87901e7018369dda2fbd4bd7850400e7f4362e91",
        "Created": "2022-11-26T05:50:32.12499544Z",
        "Scope": "global",
        "Driver": "overlay",
        "EnableIPv6": false,
        "IPAM": {
            "Driver": "default",
            "Options": {},
            "Config": [
                {
                    "Subnet": "192.168.0.0/24",
                    "Gateway": "192.168.0.1"
                }
            ]
        },
        "Internal": false,
        "Attachable": false,
        "Ingress": false,
        "ConfigFrom": {
            "Network": ""
        },
        "ConfigOnly": false,
        "Containers": {},
        "Options": {},
        "Labels": {}
    }
]
  1. 测试互通
# 所有节点创建测试容器
$ docker run -it -d --net=multi_host --name busybox-node1 busybox # kubesphere-master 配置
$ docker run -it -d --net=multi_host --name busybox-node2 busybox # kubesphere-client 配置
# kubesphere-master 配置
$ docker exec -it busybox-node1 ifconfig
eth0      Link encap:Ethernet  HWaddr 02:42:C0:A8:00:02  
          inet addr:192.168.0.2  Bcast:192.168.0.255  Mask:255.255.255.0
          UP BROADCAST RUNNING MULTICAST  MTU:1450  Metric:1
          RX packets:1 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0 
          RX bytes:54 (54.0 B)  TX bytes:0 (0.0 B)

eth1      Link encap:Ethernet  HWaddr 02:42:AC:12:00:02  
          inet addr:172.18.0.2  Bcast:172.18.255.255  Mask:255.255.0.0
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:10 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0 
          RX bytes:876 (876.0 B)  TX bytes:0 (0.0 B)

lo        Link encap:Local Loopback  
          inet addr:127.0.0.1  Mask:255.0.0.0
          UP LOOPBACK RUNNING  MTU:65536  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)

# kubesphere-client 配置
$ docker exec -it busybox-node2 ifconfig
eth0      Link encap:Ethernet  HWaddr 02:42:C0:A8:00:03  
          inet addr:192.168.0.3  Bcast:192.168.0.255  Mask:255.255.255.0
          UP BROADCAST RUNNING MULTICAST  MTU:1450  Metric:1
          RX packets:1 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0 
          RX bytes:54 (54.0 B)  TX bytes:0 (0.0 B)

eth1      Link encap:Ethernet  HWaddr 02:42:AC:12:00:02  
          inet addr:172.18.0.2  Bcast:172.18.255.255  Mask:255.255.0.0
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:11 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:0 
          RX bytes:946 (946.0 B)  TX bytes:0 (0.0 B)

lo        Link encap:Local Loopback  
          inet addr:127.0.0.1  Mask:255.0.0.0
          UP LOOPBACK RUNNING  MTU:65536  Metric:1
          RX packets:0 errors:0 dropped:0 overruns:0 frame:0
          TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:0 (0.0 B)  TX bytes:0 (0.0 B)

# 容器连通性测试(网关连通性及容器之间连通性)
$ docker exec -it busybox-node1 ping -c 1 -W 1 192.168.0.1
PING 192.168.0.1 (192.168.0.1): 56 data bytes
64 bytes from 192.168.0.1: seq=0 ttl=64 time=0.128 ms

--- 192.168.0.1 ping statistics ---
1 packets transmitted, 1 packets received, 0% packet loss
round-trip min/avg/max = 0.128/0.128/0.128 ms
$ docker exec -it busybox-node1 ping -c 1 -W 1 192.168.0.3
PING 192.168.0.3 (192.168.0.3): 56 data bytes
64 bytes from 192.168.0.3: seq=0 ttl=64 time=0.812 ms

--- 192.168.0.3 ping statistics ---
1 packets transmitted, 1 packets received, 0% packet loss
round-trip min/avg/max = 0.812/0.812/0.812 ms

2.3.3 Docker Overlay Network 工作流程

01 Docker 进阶 %26 Kubernetes 入门 - 图11

范例:测试 Docker Overlay Network 工作流程

$ apt install -y bridge-utils
$ brctl show
bridge name     bridge id               STP enabled     interfaces
docker0         8000.0242102ffee7       no
docker_gwbridge         8000.0242b1a7b4f0       no              veth41957d1

# 查看Docker网络命名空间
$ ln -s /var/run/docker/netns /var/run/netns
$ ip netns ls 
823a7c5be987 (id: 1)
2-1633d3a2b7 (id: 0)

# 查看网络命名空间的IP地址信息
$ ip netns exec 2-1633d3a2b7 ip addr 
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
2: br0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1450 qdisc noqueue state UP group default 
    link/ether 56:04:f6:8b:a2:09 brd ff:ff:ff:ff:ff:ff
    inet 192.168.0.1/24 brd 192.168.0.255 scope global br0
       valid_lft forever preferred_lft forever
# 会出现一个VXlan的设备
19: vxlan0@if19: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1450 qdisc noqueue master br0 state UNKNOWN group default 
    link/ether 6e:f5:75:32:85:ea brd ff:ff:ff:ff:ff:ff link-netnsid 0
21: veth0@if20: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1450 qdisc noqueue master br0 state UP group default
    link/ether 56:04:f6:8b:a2:09 brd ff:ff:ff:ff:ff:ff link-netns 823a7c5be987

$ ip netns exec 823a7c5be987 ip addr 
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
20: eth0@if21: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1450 qdisc noqueue state UP group default 
    link/ether 02:42:c0:a8:00:02 brd ff:ff:ff:ff:ff:ff link-netns 2-1633d3a2b7
    inet 192.168.0.2/24 brd 192.168.0.255 scope global eth0
       valid_lft forever preferred_lft forever
22: eth1@if23: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default 
    link/ether 02:42:ac:12:00:02 brd ff:ff:ff:ff:ff:ff link-netnsid 1
    inet 172.18.0.2/16 brd 172.18.255.255 scope global eth1
       valid_lft forever preferred_lft forever
# 网络命名空间与容器的命名空间显示是大致一致的!

# 查看防火墙的策略
$ iptables -vnL
Chain INPUT (policy ACCEPT 12645 packets, 2379K bytes)
 pkts bytes target     prot opt in     out     source               destination         

Chain FORWARD (policy DROP 0 packets, 0 bytes)
 pkts bytes target     prot opt in     out     source               destination         
    0     0 DOCKER-USER  all  --  *      *       0.0.0.0/0            0.0.0.0/0           
    0     0 DOCKER-ISOLATION-STAGE-1  all  --  *      *       0.0.0.0/0            0.0.0.0/0           
    0     0 ACCEPT     all  --  *      docker_gwbridge  0.0.0.0/0            0.0.0.0/0            ctstate RELATED,ESTABLISHED
    0     0 DOCKER     all  --  *      docker_gwbridge  0.0.0.0/0            0.0.0.0/0           
    0     0 ACCEPT     all  --  docker_gwbridge !docker_gwbridge  0.0.0.0/0            0.0.0.0/0           
    0     0 ACCEPT     all  --  *      docker0  0.0.0.0/0            0.0.0.0/0            ctstate RELATED,ESTABLISHED
    0     0 DOCKER     all  --  *      docker0  0.0.0.0/0            0.0.0.0/0           
    0     0 ACCEPT     all  --  docker0 !docker0  0.0.0.0/0            0.0.0.0/0           
    0     0 ACCEPT     all  --  docker0 docker0  0.0.0.0/0            0.0.0.0/0           
    0     0 DROP       all  --  docker_gwbridge docker_gwbridge  0.0.0.0/0            0.0.0.0/0           

Chain OUTPUT (policy ACCEPT 12631 packets, 2906K bytes)
 pkts bytes target     prot opt in     out     source               destination         

Chain DOCKER (2 references)
 pkts bytes target     prot opt in     out     source               destination         

Chain DOCKER-ISOLATION-STAGE-1 (1 references)
 pkts bytes target     prot opt in     out     source               destination         
    0     0 DOCKER-ISOLATION-STAGE-2  all  --  docker_gwbridge !docker_gwbridge  0.0.0.0/0            0.0.0.0/0           
    0     0 DOCKER-ISOLATION-STAGE-2  all  --  docker0 !docker0  0.0.0.0/0            0.0.0.0/0           
    0     0 RETURN     all  --  *      *       0.0.0.0/0            0.0.0.0/0           

Chain DOCKER-ISOLATION-STAGE-2 (2 references)
 pkts bytes target     prot opt in     out     source               destination         
    0     0 DROP       all  --  *      docker_gwbridge  0.0.0.0/0            0.0.0.0/0           
    0     0 DROP       all  --  *      docker0  0.0.0.0/0            0.0.0.0/0           
    0     0 RETURN     all  --  *      *       0.0.0.0/0            0.0.0.0/0           

Chain DOCKER-USER (1 references)
 pkts bytes target     prot opt in     out     source               destination         
    0     0 RETURN     all  --  *      *       0.0.0.0/0            0.0.0.0/0

2.4 Docker Macvlan

<font style="color:rgb(199, 37, 78);background-color:rgb(242, 242, 242);">macvlan</font>是可以虚拟mac地址,单独的macvlan存在意义不大,结合docker给每一个容器都虚拟一个<font style="color:rgb(199, 37, 78);background-color:rgb(242, 242, 242);">mac</font>地址,这样每个容器在局域网中都相当于一个独立的主机。在 Docker 中,macvlan 是众多 Docker 网络模型中的一种,并且是一种跨主机的网络模型,作为一种驱动(driver)启用(-d 参数指定),Docker macvlan 只支持 bridge 模式。Macvlan 是 Docker 的网络驱动,也是 Linux 内核的模块。利用该网络驱动实现宿主机的多个子接口来划分VLAN,以实现多种子网之间的划分,并且同个子网之间是可以相互通信的。

Reference:

https://docs.docker.com/network/macvlan/

https://www.cnblogs.com/bakari/p/10893589.html

2.4.1 Macvlan Bridge模式:

Macvlan:物理地址网络为每个运行的容器分配了使其暴露在运行的物理网络MAC地址。Docker进程使用物理地址(Mac地址)为容器分配IP并通过此种方式进行路由。在和其他通过Docker主机路由方式的网络对比下,Macvlan是对物理网络有直连需求的容器集群最佳的网络。Macvlan和使用交换机配置网络的方法和模式一致,对传统网络的理解和使用经验可以直接用在Macvlan上。不依靠第三方的存储,完全由Docker自身实现管理的。

Macvlan Bridge 直接桥接到宿主机的物理网卡中。容器直接桥接到宿主机的同网段(与Docker Bridge物理模式类似)。

  1. 创建Macvlan网络
# subnet:子网
# ip-range:docker自动分配ip范围,防止和局域网内其他主机重复
# gateway:网关
# aux-address:docker分配ip时排除的ip(这个ip有其他用途)
# parent:父接口,也就是host主机的物理网卡
# 以上参数强烈建议都指定,可以减少不必要的麻烦
# docker network create -d macvlan \
#   --subnet=192.168.10.0/24 \
#   --ip-range=192.168.10.32/28 \
#   --gateway=192.168.10.1 \
#   --aux-address="my-router=192.168.32.33" \
#   -o parent=eth0 macnet

# 所有的节点执行同步
docker network create -d macvlan --subnet=172.100.1.0/24 --gateway=172.100.1.1 -o parent=eth0 macvlan_net
  1. 测试互通
# 将容器网络模式设置为macvlan_net,并且需要手动设置容器的IP地址
# 不手动设置容器的IP地址,会出现IP地址冲突的现象

# kubesphere-master 执行
$ docker run -it --net macvlan_net --ip=172.100.1.10 busybox
# 查看容器的路由信息
/ # route -n 
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
0.0.0.0         172.100.1.1     0.0.0.0         UG    0      0        0 eth0
172.100.1.0     0.0.0.0         255.255.255.0   U     0      0        0 eth0
/ # ip addr 
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
24: eth0@if2: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1500 qdisc noqueue 
    link/ether 02:42:ac:64:01:0a brd ff:ff:ff:ff:ff:ff
    inet 172.100.1.10/24 brd 172.100.1.255 scope global eth0
       valid_lft forever preferred_lft forever

# kubesphere-client 执行
$ docker run -it --net macvlan_net --ip=172.100.1.11 busybox sh
# $ docker run -it --net macvlan_net --ip=172.100.1.11 busybox ping -c 4 -W 1 172.100.1.10
$ docker run -it --net macvlan_net --ip=172.100.1.11 busybox ping -c 2 -W 1 www.baidu.com
PING www.baidu.com (183.232.231.174): 56 data bytes

--- www.baidu.com ping statistics ---
2 packets transmitted, 0 packets received, 100% packet loss
$ docker run -it --net macvlan_net --ip=172.100.1.11 busybox ping -c 2 -W 1 10.0.0.100
PING 10.0.0.100 (10.0.0.100): 56 data bytes

--- 10.0.0.100 ping statistics ---
2 packets transmitted, 0 packets received, 100% packet loss
# Macvlan Bridge 其实就是一个VLAN的形式,由Docker进行管理。与宿主机的网络是一种隔离的状态,不能上外网!

01 Docker 进阶 %26 Kubernetes 入门 - 图12

:::color1

Macvlan Bridge 模式并没有创建新的网络命名空间。当节点1的<font style="color:#D22D8D;">容器1</font>的连通性测试到另一个节点2的<font style="color:#D22D8D;">容器2</font><font style="color:#D22D8D;">容器1</font>会通过Mac请求到Macvlan 的网关,该网关会查询其路由表和ARP表,将数据包转发到 eth0 进行发送,作为ARP的广播!节点2就可以收到该ARP的广播,进而查询到节点2中的<font style="color:#D22D8D;">容器2</font><font style="color:#D22D8D;">其实就是在虚拟化二层网络的基础上借助宿主机三层路由完成通信过程!</font> Macvlan 是一种网卡虚拟化技术,能够将一张网卡虚拟出多张网卡。 Macvlan 的四种通信模式,常用模式是 bridge。在 Docker 中,Macvlan 只支持 bridge 模式。 相同 Macvlan 可以通信,不同 Macvlan 二层无法通信,可以借助三层路由完成通信。 注意:但是目前有个问题:<font style="color:#D22D8D;background-color:rgb(242, 242, 242);">host</font><font style="color:#D22D8D;background-color:rgb(242, 242, 242);">container</font>是无法互通的,因为是<font style="color:#D22D8D;">macvlan</font>的原因,同一个网口的流量是无法回传,<font style="color:#D22D8D;">(对于</font>**<font style="color:#D22D8D;">同一个数据包</font>**<font style="color:#D22D8D;">来讲,数据包从接口发送出去,那么就不可能该数据包再返回到该接口)</font>的,除非在外部有一个支持<font style="color:#D22D8D;background-color:rgb(242, 242, 242);">VEPA</font>或者<font style="color:#D22D8D;background-color:rgb(242, 242, 242);">VN-Link</font>的交换机。 注意:一个 Macvlan 只能够绑定一个物理接口,或者一个子接口。

01 Docker 进阶 %26 Kubernetes 入门 - 图13

:::

创建一个与宿主机同网段的 MacVLAN 的Docker网络

$ docker network rm macvlan_net

# 创建一个与宿主机同网段的 MacVLAN 的Docker网络
# 所有节点执行
$ docker network create -d macvlan --subnet 10.0.0.0/24 --gateway 10.0.0.2 -o parent=eth0 macvlan_host_net
$ docker run -it -d --network macvlan_host_net --ip=10.0.0.200 busybox sh
$ docker ps -l 
CONTAINER ID   IMAGE     COMMAND   CREATED         STATUS         PORTS     NAMES
72981a81e756   busybox   "sh"      3 seconds ago   Up 2 seconds             nifty_wilbur
docker exec -it nifty_wilbur sh
/ # ip addr 
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
27: eth0@if2: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1500 qdisc noqueue 
    link/ether 02:42:0a:00:00:c8 brd ff:ff:ff:ff:ff:ff
    inet 10.0.0.200/24 brd 10.0.0.255 scope global eth0
       valid_lft forever preferred_lft forever
/ # ping -c 1 -W 1 www.baidu.com
PING www.baidu.com (183.232.231.172): 56 data bytes
64 bytes from 183.232.231.172: seq=0 ttl=128 time=16.960 ms

--- www.baidu.com ping statistics ---
1 packets transmitted, 1 packets received, 0% packet loss
round-trip min/avg/max = 16.960/16.960/16.960 ms
/ # ping -c 1 -W 1 10.0.0.100
PING 10.0.0.100 (10.0.0.100): 56 data bytes
64 bytes from 10.0.0.100: seq=0 ttl=64 time=0.658 ms

--- 10.0.0.100 ping statistics ---
1 packets transmitted, 1 packets received, 0% packet loss
round-trip min/avg/max = 0.658/0.658/0.658 ms

2.4.2 Macvlan VLAN Bridge模式:

  1. 创建一个VLAN,VLAN ID 50
# 所有节点执行
$ ip link add link eth0 name eth0.50 type vlan id 50
$ ip addr
28: eth0.50@eth0: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN group default qlen 1000
    link/ether 00:0c:29:0f:dd:0c brd ff:ff:ff:ff:ff:ff
  1. 创建Macvlan网络
# 所有节点执行
$ docker network create -d macvlan --subnet=172.20.50.0/24 --gateway=172.20.50.1 -o parent=eth0.50 macvlan_net50
$ docker network ls 
NETWORK ID     NAME               DRIVER    SCOPE
79961fd3c47c   bridge             bridge    local
e99aef116287   docker_gwbridge    bridge    local
91a9e5257fb4   host               host      local
f22f9ee544ae   macvlan_host_net   macvlan   local
fe4edd91bb0f   macvlan_net50      macvlan   local
1633d3a2b72f   multi_host         overlay   global
0279a9dbc65d   none               null      local
  1. 测试互通
# kubesphere-master 执行
docker run -it --net macvlan_net50 --ip=172.20.50.10 busybox

# kubesphere-client 执行
docker run -it --net macvlan_net50 --ip=172.20.50.11 busybox ping 172.20.50.10

# 若发现通信网络有问题,可以重启机器将MacVlan初始化,再执行

2.5 Weave

2.5.1 Weave 介绍

weave是由zett.io公司开发的,它能够创建一个虚拟网络,用于连接部署在多台主机上的docker容器,这样容器就像被接入了同一个网络交换机,那些使用网络的应用程序不必去配置端口映射和链接等信息。外部设备能够访问weave网络上的应用程序容器所提供的服务,同时已有的内部系统也能够暴露到应用程序容器上。weave能够穿透防火墙并运行在部分连接的网络上,另外,weave的通信支持加密,所以用户可以从一个不受信任的网络连接到主机。

Weave在Docker主机之间实现Overlay网络,使用业界标准VXLAN封装,基于UDP传输,也可以加密传输。

Weave Net创建一个连接多个Docker主机的虚拟网络,类似于一个以太网交换机,所有的容器都连接到这上面,互相通信。Weave Net由多个peer组成,Weave路由器运行不同Docker主机上,是一个用户空间的进程;每个peer都有一个名称,重启保持不变。它们通过TCP连接彼此,建立后交换拓扑信息。

Weave Net可以在具有编号拓扑的部分连接的网络中路由数据包。例如,在下面网络中,peer1直接连接peer2和peer3,但是如果peer1需要发送数据包到peer4和peer5,则必须先将其发送到peer3。

01 Docker 进阶 %26 Kubernetes 入门 - 图14

Weave Net实现了Docker主机之间的覆盖网络。在没有启用快速数据路径的情况下,每个数据包都被封装在隧道协议标头中并发送到目标主机,在该目标主机中标头被删除。Weave路由器是一个用户空间进程,这意味着数据包沿着一条蜿蜒的路径进出Linux内核:

01 Docker 进阶 %26 Kubernetes 入门 - 图15

Weave Net中的"fast data path"使用Linux内核的OpenvSwich datapath模块。该模块使Weave Net路由器能够告知内核如何处理数据包。OpenvSwich datapath和VXLAN功能在Linux.内核版本3.12+才支持,如果内核不支持,则Weave Net使用"user mode"数据包路径。Weave Net会自动选择两台主机之间最快的路径传输数据,提供近原生吞吐量和延迟。

Weave 的特点:

  1. 应用隔离:不同子网容器之间默认隔离的,即便它们位于同一台物理机上也相互不通;不同物理机之间的容器默认也是隔离的
  2. 物理机之间容器互通:weave connect $other_host
  3. 动态添加网络:对于不是通过weave启动的容器,可以通过weave attach 10.0.1.1/24 $id来添加网络(detach删除网络)
  4. 安全性:可以通过weave launch -password weave设置一个密码用于weave peers之间加密通信
  5. 与宿主机网络通信:weave expose 10.0.1.102/24,这个ip会配在weave网桥上
  6. 查看weave路由状态:weave ps
  7. 通过nat实现外网访问docker容器

01 Docker 进阶 %26 Kubernetes 入门 - 图16

01 Docker 进阶 %26 Kubernetes 入门 - 图17

:::color1

Weave是Github上一个比较热门的Docker容器网络方案,具有非常良好的易用性且功能强大。Weave 的框架它包含了两大主要组件: 1)Weave:用户态的shell脚本,用于安装Weave,将container连接到Weave虚拟网络。并为它们分配IP。 2)Weaver:运行于container内,每个Weave网络内的主机都要运行,是一个Go语言实现的虚拟网络路由器。不同主机之间的网络通信依赖于Weaver路由。 Weave通过创建虚拟网络使Docker容器能够跨主机通信并能够自动相互发现。 通过weave网络,由多个容器构成的基于微服务架构的应用可以运行在任何地方:主机,多主机,云上或者数据中心。 应用程序使用网络就好像容器是插在同一个网络交换机上一样,不需要配置端口映射,连接等。 在weave网络中,使用应用容器提供的服务可以暴露给外部,而不用管它们运行在何处。类似地,现存的内部系统也可以接受来自于应用容器的请求,而不管容器运行于何处。 一个Weave网络由一系列的‘peers’构成——这些weave路由器存在于不同的主机上。每个peer都由一个名字,这个名字在重启之后保持不变.这个名字便于用户理解和区分日志信息。 每个peer在每次运行时都会有一个不同的唯一标识符(UID).对于路由器而言,这些标识符不是透明的,尽管名字默认是路由器的MAC地址。 Weave路由器之间建立起TCP连接,通过这个连接进行心跳握手和拓扑信息交换,这些连接可以通过配置进行加密。 peers之间还会建立UDP连接,也可以进行加密,这些UDP连接用于网络包的封装,这些连接是双工的而且可以穿越防火墙。 Weave网络在主机上创建一个网桥,每个容器通过veth pari连接到网桥上,容器由用户或者weave网络的IPADM分配IP地址。

:::

2.5.2 Weave 部署

官方文档: https://www.weave.works/docs/net/latest/install/installing-weave

使用前提:

  1. 确保Linux内核版本3.8+Docker1.10+
  2. 节点之间如果有防火墙时,必须彼此放行TCP 6783UDP 6783/6784端口,这是Weave控制和数据端口。
  3. 主机名不能相同,通过主机名标识子网。

部署:

安装Docker

# step 1: 安装必要的一些系统工具
sudo apt-get update
sudo apt-get -y install apt-transport-https ca-certificates curl software-properties-common

# step 2: 安装GPG证书
curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -

# Step 3: 写入软件源信息
sudo add-apt-repository "deb [arch=amd64] https://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable"

# Step 4: 更新并安装Docker-CE
sudo apt-get -y update
sudo apt-get -y install docker-ce

# 安装指定版本的Docker-CE:
# Step 1: 查找Docker-CE的版本:
# apt-cache madison docker-ce
#   docker-ce | 17.03.1~ce-0~ubuntu-xenial | https://mirrors.aliyun.com/docker-ce/linux/ubuntu xenial/stable amd64 Packages
#   docker-ce | 17.03.0~ce-0~ubuntu-xenial | https://mirrors.aliyun.com/docker-ce/linux/ubuntu xenial/stable amd64 Packages
# Step 2: 安装指定版本的Docker-CE: (VERSION例如上面的17.03.1~ce-0~ubuntu-xenial)
# sudo apt-get -y install docker-ce=[VERSION]

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://po13h3y1.mirror.aliyuncs.com","http://hub-mirror.c.163.com","https://mirror.ccs.tencentyun.com","http://f1361db2.m.daocloud.io"],
  "exec-opts": ["native.cgroupdriver=systemd"],
  "log-driver": "json-file",
  "log-opts": {
    "max-size": "100m"
  },
  "storage-driver": "overlay2"
}
EOF

sudo systemctl daemon-reload && sudo systemctl restart docker
  1. 安装 Weave
sudo curl -L git.io/weave -o /usr/local/bin/weave
sudo chmod a+x /usr/local/bin/weave
  1. 启动并与其他主机建立连接
# 10.0.0.100
weave-01:~# weave launch 10.0.0.101

# 10.0.0.101
# 格式: weave launch <ip address>
weave-02:~# weave launch 10.0.0.100

# 查看 weave 进程(Docker 和 相同)
$ docker ps -a 
CONTAINER ID   IMAGE                        COMMAND                  CREATED         STATUS         PORTS     NAMES
a0cdadd6af76   weaveworks/weave:2.8.1       "/home/weave/weaver …"   2 minutes ago   Up 2 minutes             weave
6c99e03d4cbc   weaveworks/weaveexec:2.8.1   "data-only"              2 minutes ago   Created                  weavevolumes-2.8.1
9df415d01bfc   weaveworks/weavedb:latest    "data-only"              2 minutes ago   Created                  weavedb
$ ps -ef | grep weave
root        9051    9033  0 12:32 ?        00:00:00 /home/weave/weaver --port 6783 --nickname ubuntu-cluster01 --host-root=/host --docker-bridge docker0 --weave-bridge weave --datapath datapath --ipalloc-range 10.32.0.0/12 --dns-listen-address 172.17.0.1:53 --http-addr 127.0.0.1:6784 --status-addr 127.0.0.1:6782 --resolv-conf /var/run/weave/etc/stub-resolv.conf -H unix:///var/run/weave/weave.sock --plugin --proxy 10.0.0.101
root        9641    1372  0 12:35 pts/0    00:00:00 grep --color=auto weave

# 查看Weave状态
$ weave status connections
<- 10.0.0.101:36825      established fastdp be:df:a6:58:c4:5b(ubuntu-cluster02) mtu=1376
$ weave status

        Version: 2.8.1 (up to date; next check at 2022/11/26 17:31:37)

        Service: router
       Protocol: weave 1..2
           Name: 62:31:18:ff:de:8a(ubuntu-cluster01)
     Encryption: disabled
  PeerDiscovery: enabled
        Targets: 1
    Connections: 1 (1 established)
          Peers: 2 (with 2 established connections)
 TrustedSubnets: none

        Service: ipam
         Status: idle
          Range: 10.32.0.0/12
  DefaultSubnet: 10.32.0.0/12

        Service: dns
         Domain: weave.local.
       Upstream: none
            TTL: 1
        Entries: 0

        Service: proxy
        Address: unix:///var/run/weave/weave.sock

        Service: plugin (legacy)
     DriverName: weave

# 查看Docker Network
$ docker network ls 
NETWORK ID     NAME      DRIVER      SCOPE
56ae06b199c5   bridge    bridge      local
79fd1c4f4207   host      host        local
7ed85ed91100   none      null        local
2670edf4b724   weave     weavemesh   local
  1. 使用Weave网络创建容器
# 方式1:
eval $(weave env) # 所有节点执行,创建的容器默认会添加到 Weave 网络中
# ubuntu-cluster01 执行
$ docker run -it busybox
/ # ip addr 
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
20: eth0@if21: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1500 qdisc noqueue 
    link/ether 02:42:ac:11:00:02 brd ff:ff:ff:ff:ff:ff
    inet 172.17.0.2/16 brd 172.17.255.255 scope global eth0
       valid_lft forever preferred_lft forever
22: ethwe@if23: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1376 qdisc noqueue 
    link/ether 22:61:ef:5a:96:77 brd ff:ff:ff:ff:ff:ff
    inet 10.32.0.2/12 brd 10.47.255.255 scope global ethwe
       valid_lft forever preferred_lft forever
# 容器连通性测试
/ # ping -c 1 -W 1 10.40.0.1
PING 10.40.0.1 (10.40.0.1): 56 data bytes
64 bytes from 10.40.0.1: seq=0 ttl=64 time=1.490 ms

--- 10.40.0.1 ping statistics ---
1 packets transmitted, 1 packets received, 0% packet loss
round-trip min/avg/max = 1.490/1.490/1.490 ms
# 容器可以连通宿主机外网
/ # ping -c 1 -W 1 www.baidu.com
PING www.baidu.com (183.232.231.174): 56 data bytes
64 bytes from 183.232.231.174: seq=0 ttl=127 time=30.830 ms

--- www.baidu.com ping statistics ---
1 packets transmitted, 1 packets received, 0% packet loss
round-trip min/avg/max = 30.830/30.830/30.830 ms

# ubuntu-cluster02 执行
$ docker run -it busybox
/ # ip addr 
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
17: eth0@if18: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1500 qdisc noqueue 
    link/ether 02:42:ac:11:00:02 brd ff:ff:ff:ff:ff:ff
    inet 172.17.0.2/16 brd 172.17.255.255 scope global eth0
       valid_lft forever preferred_lft forever
19: ethwe@if20: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1376 qdisc noqueue 
    link/ether 6a:bb:65:d3:80:f0 brd ff:ff:ff:ff:ff:ff
    inet 10.40.0.1/12 brd 10.47.255.255 scope global ethwe
       valid_lft forever preferred_lft forever

########################################################################################################################

# 所有节点执行
# 方式2:
docker run -it -d --net=weave busybox
# Weave 要比 Flannel 更加的强大
# ubuntu-cluster01 执行
$ docker ps 
CONTAINER ID   IMAGE                    COMMAND                  CREATED          STATUS          PORTS     NAMES
d6c7802450de   busybox                  "sh"                     2 minutes ago    Up 2 minutes              funny_saha
a0cdadd6af76   weaveworks/weave:2.8.1   "/home/weave/weaver …"   10 minutes ago   Up 10 minutes             weave
$ docker exec -it funny_saha /bin/sh
/ # ip addr 
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
15: ethwe0@if16: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1376 qdisc noqueue 
    link/ether 52:fc:49:07:dc:40 brd ff:ff:ff:ff:ff:ff
    inet 10.32.0.1/12 brd 10.47.255.255 scope global ethwe0
       valid_lft forever preferred_lft forever
18: eth0@if19: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1500 qdisc noqueue 
    link/ether 02:42:ac:12:00:02 brd ff:ff:ff:ff:ff:ff
    inet 172.18.0.2/16 brd 172.18.255.255 scope global eth0
       valid_lft forever preferred_lft forever
# 容器连通性测试
/ # ping -c 1 -W 1 10.40.0.0
PING 10.40.0.0 (10.40.0.0): 56 data bytes
64 bytes from 10.40.0.0: seq=0 ttl=64 time=2.450 ms

--- 10.40.0.0 ping statistics ---
1 packets transmitted, 1 packets received, 0% packet loss
round-trip min/avg/max = 2.450/2.450/2.450 ms

# ubuntu-cluster02 执行
$ docker ps 
CONTAINER ID   IMAGE                    COMMAND                  CREATED         STATUS         PORTS     NAMES
24fa2ba12eb7   busybox                  "sh"                     2 minutes ago   Up 2 minutes             keen_wozniak
198bba761658   weaveworks/weave:2.8.1   "/home/weave/weaver …"   9 minutes ago   Up 9 minutes             weave
$ docker exec -it keen_wozniak /bin/sh
/ # ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
12: ethwe0@if13: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1376 qdisc noqueue 
    link/ether 16:c7:c5:66:81:08 brd ff:ff:ff:ff:ff:ff
    inet 10.40.0.0/12 brd 10.47.255.255 scope global ethwe0
       valid_lft forever preferred_lft forever
15: eth0@if16: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1500 qdisc noqueue 
    link/ether 02:42:ac:12:00:02 brd ff:ff:ff:ff:ff:ff
    inet 172.18.0.2/16 brd 172.18.255.255 scope global eth0
       valid_lft forever preferred_lft forever
  1. 查看Weave的信息
# 查看当前分配的容器
$ weave ps 
weave:expose 62:31:18:ff:de:8a
3be8f8e8f68a 22:61:ef:5a:96:77 10.32.0.2/12
d6c7802450de 52:fc:49:07:dc:40 10.32.0.1/12

# 查看weave相互之间节点建立的关系
$ weave status peers
62:31:18:ff:de:8a(ubuntu-cluster01)
   <- 10.0.0.101:36825      be:df:a6:58:c4:5b(ubuntu-cluster02)   established
be:df:a6:58:c4:5b(ubuntu-cluster02)
   -> 10.0.0.100:6783       62:31:18:ff:de:8a(ubuntu-cluster01)   established

# 查看weave版本
$ weave version 
weave script 2.8.1
weave 2.8.1

# 查看网桥信息
$ apt install -y bridge-utils
$ brctl show
bridge name     bridge id               STP enabled     interfaces
docker0         8000.0242cc4c48a4       no              vethdc43521
docker_gwbridge 8000.0242b455ce02       no              vetha714a91
weave           8000.623118ffde8a       no              vethwe-bridge
                                                        vethwepl11240
                                                        vethwlb3b8944d3

2.5.3 Weave 命令

# 安装weave
curl -L git.io/weave -o /usr/local/bin/weave

# 通过weave setup预先将weave相关的容器Image下载到各个节点
weave setup

# 启动跨多节点(peer) weave network
weave launch –no-dns 192.168.56.7 192.168.59

# 查看节点weave之间的连接状态:
weave status connections

# weave网络的整体状态:
weave status

# 查看状态详情
weave status connections

# 查看weave相互之间节点建立的关系
weave status peers

# 查看当前分配的容器
weave ps

# 查看weave当前版本
weave version

# 启动并与其他主机建立连接,启动weave并下载镜像
weave launch

# 进行连接 IP连接对端服务器
weave launch

# 使用weave代理
weave env

# 执行输出|来自weave env的输出
export DOCKER_HOST=unix:///var/run/weave/weave.sock

# 关闭weave
weave stop

# 关闭weave env代理
export DOCKER=OPTS=

2.5.4 Weave 工作原理

01 Docker 进阶 %26 Kubernetes 入门 - 图18

1、ethwe 会将数据包发送给vethwe-bridge网桥。

2、vethwe-bridge接收到数据包后由weave去处理这个数据,通过UDP6783数据端口依照weave的路由表转发到下一路由节点。

3、如果该节点就是目的地,本地weave会把信息转发到内核的TCP协议站,再转发到目的节点。

weave通过在docker集群的每个主机上启动虚拟路由器,将主机作为路由器,形成互联互通的网络拓扑,在此基础上,实现容器的跨主机通信。其主机网络拓扑参见下图:

01 Docker 进阶 %26 Kubernetes 入门 - 图19

如上图所示,在每一个部署Docker的主机(可能是物理机也可能是虚拟机)上都部署有一个W(即weave router,它本身也可以以一个容器的形式部署)。weave网络是由这些weave routers组成的对等端点(peer)构成,并且可以通过weave命令行定制网络拓扑。

每个部署了weave router的主机之间都会建立TCP和UDP两个连接,保证weave router之间控制面流量和数据面流量的通过。控制面由weave routers之间建立的TCP连接构成,通过它进行握手和拓扑关系信息的交换通信。控制面的通信可以被配置为加密通信。而数据面由weave routers之间建立的UDP连接构成,这些连接大部分都会加密。这些连接都是全双工的,并且可以穿越防火墙。 当容器通过weave进行跨主机通信时,其网络通信模型可以参考下图:

01 Docker 进阶 %26 Kubernetes 入门 - 图20

从上面的网络模型图中可以看出,对每一个weave网络中的容器,weave都会创建一个网桥,并且在网桥和每个容器之间创建一个veth pair,一端作为容器网卡加入到容器的网络命名空间中,并为容器网卡配置ip和相应的掩码,一端连接在网桥上,最终通过宿主机上weave router将流量转发到对端主机上。

其基本过程如下:

1)容器流量通过veth pair到达宿主机上weave router网桥上。

2)weave router在混杂模式下使用pcap在网桥上截获网络数据包,并排除由内核直接通过网桥转发的数据流量,例如本子网内部、本地容器之间的数据以及宿主机和本地容器之间的流量。捕获的包通过UDP转发到所其他主机的weave router端。

3)在接收端,weave router通过pcap将包注入到网桥上的接口,通过网桥的上的veth pair,将流量分发到容器的网卡上。weave默认基于UDP承载容器之间的数据包,并且可以完全自定义整个集群的网络拓扑,但从性能和使用角度来看,还是有比较大的缺陷的:

→ weave自定义容器数据包的封包解包方式,不够通用,传输效率比较低,性能上的损失也比较大。

→ 集群配置比较负载,需要通过weave命令行来手工构建网络拓扑,在大规模集群的情况下,加重了管理员的负担。

2.5.5 Weave 其他功能

  • IP地址管理(IPAM)

Weave 自动为容器分配唯一的IP地址。可通过weave ps查看命名和发现

  • 命名的容器

自动会注册到Weave DNS中,并可以通过容器名称访问。

# ubuntu-cluster01 执行
$ docker run -itd --name busybox-node1 busybox
$ docker exec -it busybox-node1 /bin/sh
/ # ip addr 
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
30: eth0@if31: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1500 qdisc noqueue 
    link/ether 02:42:ac:11:00:03 brd ff:ff:ff:ff:ff:ff
    inet 172.17.0.3/16 brd 172.17.255.255 scope global eth0
       valid_lft forever preferred_lft forever
32: ethwe@if33: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1376 qdisc noqueue 
    link/ether da:87:cf:3d:95:0d brd ff:ff:ff:ff:ff:ff
    inet 10.32.0.3/12 brd 10.47.255.255 scope global ethwe
       valid_lft forever preferred_lft forever

# ubuntu-cluster02 执行
$ docker run -itd --name busybox-node2 busybox
$ docker exec -it busybox-node2 /bin/sh
/ # ping -c 1 -W 1 busybox-node1
PING busybox-node1 (10.32.0.3): 56 data bytes
64 bytes from 10.32.0.3: seq=0 ttl=64 time=1.232 ms

--- busybox-node1 ping statistics ---
1 packets transmitted, 1 packets received, 0% packet loss
round-trip min/avg/max = 1.232/1.232/1.232 ms
  • 负载均衡

允许注册多个相同名称的容器(不同服务器的相同容器名),Weave DNS随机为每个请求返回地址,提供基本的负载均衡功能。

# 所有节点执行
$ docker run -itd --name busybox1 busybox

# 其中一个节点执行
$ docker run -it --name busybox-cmd busybox
/ # ping -c 1 -W 1 busybox1
PING busybox1 (10.32.0.4): 56 data bytes
64 bytes from 10.32.0.4: seq=0 ttl=64 time=1.560 ms

--- busybox1 ping statistics ---
1 packets transmitted, 1 packets received, 0% packet loss
round-trip min/avg/max = 1.560/1.560/1.560 ms
/ # ping -c 1 -W 1 busybox1
PING busybox1 (10.40.0.3): 56 data bytes
64 bytes from 10.40.0.3: seq=0 ttl=64 time=0.197 ms

--- busybox1 ping statistics ---
1 packets transmitted, 1 packets received, 0% packet loss
round-trip min/avg/max = 0.197/0.197/0.197 ms
# 会响应两个容器的IP地址,实现基本的负载均衡功能
  • 手动指定IP地址
docker run -it -e WEAVE_CIDR=10.32.0.100/24 busybox
  • 动态拓扑

可以在不停止或重新配置剩余Docker主机的情况下添加主机到Weave网络中或从Weave网络中删除

  • 容错

weave peer不断交换拓扑信息,监视和建立与其他peer的网络连接。如果有主机或网络出现故障,Weave会绕过这个主机,保证两边容器可以继续通信,当恢复时,恢复完全连接。

:::color1 这也是 Weave 比 Flannel 功能强大的原因。实现的效果类似,只不过 Weave 从部署到功能上要比 Flannel 强大。

:::

2.6 OpenSwitch

2.6.1 OVS 介绍

什么是OpenvSwich?

OpenvSwich:开放虚拟交换标准,是一种基于开源Apache2.0许可证的多层软件交换机,专门管理多租赁云计算网络环境,支持KVM、Xen等虚拟化技术。

支持以下功能:

  1. 支持标准802.1Q VLAN模块的Trunk和Access端口模式;
  2. QoS (Quality of Service)配置,及管理;
  3. 支持OpenFlow协议;
  4. 支持GRE、VXLAN、STT和LISP隧道;
  5. 具有C和Python接口配置数据库;
  6. 支持内核态和用户态的转发引擎设置;[ 内核态的处理效率要比用户态高 ]
  7. 支持流量控制及监控。

主要组成部分:

ovs-vswitchd 一个实现交换机的守护程序 ovsdb-server 一个轻量级数据库,ovs-vswitchd查询以获取其配置

ovs-dpctl 用于配置交换机的内核模块工具

ovs-vsctl 用于查看和更新ovs-vswitchd的配置工具

ovs-appctl 一个向运行OVS守护程序发送命令的工具

还提供了openflow的工具:

ovs-ofctl 用于查看和控制OpenFlow交换机和控制器

ovs-pki 用于创建和管理公钥

ovs-tcpundump 解析openflow消息

2.6.2 安装部署 OVS 并建立 GRE 隧道

节点1:10.0.0.100 容器网段: 172.17.1.0/24

节点2:10.0.0.101 容器网段: 172.17.2.0/24

# dockerd --help 可以查看docker的服务的参数
# --bip 是设置网关

# 10.0.0.100 执行
$ vim /lib/systemd/system/docker.service
[Service]
ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock --bip=172.17.1.1/24

$ sudo systemctl daemon-reload && sudo systemctl restart docker.service

# 10.0.0.101 执行
$ vim /lib/systemd/system/docker.service
[Service]
ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock --bip=172.17.2.1/24

$ sudo systemctl daemon-reload && sudo systemctl restart docker.service
  1. 安装ovs
# 所有节点执行
apt-get update
apt-get install -y openvswitch-switch bridge-utils
  1. 创建网桥并激活
# 所有节点执行
ovs-vsctl add-br br0
ip link set dev br0 up
  1. 将gre0虚拟接口加入网桥br0,并设置接口类型和对端IP地址(远程IP指定对端,GRE是点到点的隧道协议)
# remote_ip 使用对端的IP地址
$ ovs-vsctl add-port br0 gre0 -- set Interface gre0 type=gre options:remote_ip=10.0.0.101
$ ovs-vsctl add-port br0 gre0 -- set Interface gre0 type=gre options:remote_ip=10.0.0.100

# 删除
$ ovs-vsctl del-port br0 gre0
  1. 添加docker0网桥到OVS网桥br0
brctl addif docker0 br0
  1. 查看网桥信息
ovs-vsctl show
brctl show

01 Docker 进阶 %26 Kubernetes 入门 - 图21

01 Docker 进阶 %26 Kubernetes 入门 - 图22

  1. 添加静态路由
# 所有节点执行
ip route add 172.17.0.0/16 dev docker0

$ route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
0.0.0.0         10.0.0.2        0.0.0.0         UG    0      0        0 eth1
0.0.0.0         10.0.0.2        0.0.0.0         UG    0      0        0 eth0
10.0.0.0        0.0.0.0         255.255.255.0   U     0      0        0 eth1
10.0.0.0        0.0.0.0         255.255.255.0   U     0      0        0 eth0
172.17.0.0      0.0.0.0         255.255.0.0     U     0      0        0 docker0
172.17.1.0      0.0.0.0         255.255.255.0   U     0      0        0 docker0
  1. 验证互通
# 10.0.0.100 执行
$ docker run -it busybox /bin/sh
/ # ip addr 
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
2: gre0@NONE: <NOARP> mtu 1476 qdisc noop qlen 1000
    link/gre 0.0.0.0 brd 0.0.0.0
3: gretap0@NONE: <BROADCAST,MULTICAST> mtu 1462 qdisc noop qlen 1000
    link/ether 00:00:00:00:00:00 brd ff:ff:ff:ff:ff:ff
4: erspan0@NONE: <BROADCAST,MULTICAST> mtu 1450 qdisc noop qlen 1000
    link/ether 00:00:00:00:00:00 brd ff:ff:ff:ff:ff:ff
12: eth0@if13: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1500 qdisc noqueue 
    link/ether 02:42:ac:11:01:02 brd ff:ff:ff:ff:ff:ff
    inet 172.17.1.2/24 brd 172.17.1.255 scope global eth0
       valid_lft forever preferred_lft forever
# 容器之间连通性测试
/ # ping 172.17.2.2

# 10.0.0.101 执行
$ docker run -it busybox /bin/sh
/ # ip addr 
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
2: gre0@NONE: <NOARP> mtu 1476 qdisc noop qlen 1000
    link/gre 0.0.0.0 brd 0.0.0.0
3: gretap0@NONE: <BROADCAST,MULTICAST> mtu 1462 qdisc noop qlen 1000
    link/ether 00:00:00:00:00:00 brd ff:ff:ff:ff:ff:ff
4: erspan0@NONE: <BROADCAST,MULTICAST> mtu 1450 qdisc noop qlen 1000
    link/ether 00:00:00:00:00:00 brd ff:ff:ff:ff:ff:ff
11: eth0@if12: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1500 qdisc noqueue 
    link/ether 02:42:ac:11:02:02 brd ff:ff:ff:ff:ff:ff
    inet 172.17.2.2/24 brd 172.17.2.255 scope global eth0
       valid_lft forever preferred_lft forever

2.6.3 OpenvSwtich 命令示例

  1. Open vSwitch提供了ovs-vsctl、ovs-ofctl、ovs-dpctl等命令,详情如下:

01 Docker 进阶 %26 Kubernetes 入门 - 图23

ovs-vsctl:管理ovsdb-server的配置,提供OVSDB的配置方法,包括创建和删除网桥、端口等; ovs-ofctl:提供ovs-vswitchd的流表配置方法; ovs-dpctl:配置OVS内核模块,提供缓存流表的操作方法; ovsdb-tool:创建和管理OVSDB。
  1. 命令示例
1)网桥管理
命令 功能
ovs-vsctl show 显示OVS信息
ovs-vsctl add-br br-name 添加新的网桥br-name
ovs-vsctl del-br br-name 删除br-name
ovs-vsctl list-br 显示网桥br-name信息
ovs-vsctl list-ports br-name 显示网桥br-name中所有port信息
ovs-vsctl add-port br-name port-no br-name添加端口
ovs-vsctl del-port br-name port-no 删除br-name上的端口
ovs-vsctl get-controller br-name 获取br-name连接控制器信息
ovs-vsctl del-controller br-name 删除br-name连接控制器信息
ovs-vsctl set-controller br-name tcp:[ip]:__[port] br-name__ 网桥连接控制器controller
2)流表管理
命令 功能
ovs-ofctl show br-name 输出OpenFlow信息
ovs-ofctl add-flow br-name flow 添加流表项
ovs-ofctl add-flows br-name filename 文件形式批量添加流表项
ovs-ofctl del-flows br-name flow 删除交换机的流表项

2.6.4 OpenvSwtich 工作原理

01 Docker 进阶 %26 Kubernetes 入门 - 图24

OVS的datapath接收到从OVS连接的某个网络设备发来的数据包,从数据包中提取源/目的IP、源/目的MAC、端口等信息。 OVS在内核状态下查看流表结构(通过Hash),观察是否有缓存的信息可用于转发这个数据包。 假设数据包是这个网络设备发来的第一个数据包,在OVS内核中,将不会有相应的流表缓存信息存在,那么内核将不会知道如何处置这个数据包。所以内核将发送upcall给用户态。 位于用户态的ovs-vswitchd进程接收到upcall后,将检查数据库以查询数据包的目的端口是哪里,然后告诉内核应该将数据包转发到哪个端口,例如eth0。 ⑤ 内核执行用户此前设置的动作。即内核将数据包转发给端口eth0,进而数据被发送出去。

:::color1 OpenvSwtich 的扩展性比 Weave 以及 Overlay差。并且OpenvSwtich需要将服务器的路由条目配置好。

:::

:::color1 网络从原理上分析的话,原理性比较强,而且数据流的处理也是比较繁琐的。并且Docker的跨主机网络应用场景使用较少。

并且Docker跨主机网络是独立于 Docker Swarm 集群模式,以及 Kubernetes 的使用场景。

:::

2.7 Flannel

1、etcd安装并配置

# etcd 部署一台即可
$ yum install etcd -y
$ vi /etc/etcd/etcd.conf
ETCD_DATA_DIR="/var/lib/etcd/default.etcd"
ETCD_LISTEN_CLIENT_URLS= "http://10.0.0.54:2379"
ETCD_NAME="default"
ETCD_ADVERTISE_CLIENT_URLS="http://10.0.0.54:2379"

$ systemctl enable --now etcd

2、flanneld安装并配置

# 所有节点执行
$ yum install flannel -y
$ vi /etc/sysconfig/flanneld
FLANNEL_ETCD_ENDPOINTS="http://10.0.0.54:2379"
FLANNEL_ETCD_PREFIX="/atomic.io/network"

# 以下步骤可省略
$ mkdir -pv /atomic.io/network
$ systemctl enable --now flanneld

3、向etcd写入子网

$ etcdctl --endpoints="http://10.0.0.54:2379" set /atomic.io/network/config '{"Network": "172.17.0.0/16","Backend": {"Type": "vxlan"}}'

# 查看Flannel日志
$ cat /var/run/flannel/docker
DOCKER_OPT_BIP="--bip=172.17.92.1/24"
DOCKER_OPT_IPMASQ="--ip-masq=true"
DOCKER_OPT_MTU="--mtu=1450"
DOCKER_NETWORK_OPTIONS=" --bip=172.17.92.1/24 --ip-masq=true --mtu=1450"

4、配置Docker使用flannel生成的网络信息

# vi /usr/lib/systemd/system/docker.service
EnvironmentFile=/run/flannel/docker
ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock $DOCKER_NETWORK_OPTIONS

5、启动所有服务并设置开机启动

$ systemctl daemon-reload && systemctl restart docker 
# systemctl start docker 
$ systemctl enable --now docker

$ ps -ef | grep docker
root       3015      1  0 22:06 ?        00:00:00 /usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock --bip=172.17.92.1/24 --ip-masq=true --mtu=1450
root       3158   1679  0 22:06 pts/0    00:00:00 grep --color=auto docker

# 从节点会同步flanneld配置
$ cat /var/run/flannel/docker
DOCKER_OPT_BIP="--bip=172.17.95.1/24"
DOCKER_OPT_IPMASQ="--ip-masq=true"
DOCKER_OPT_MTU="--mtu=1450"
DOCKER_NETWORK_OPTIONS=" --bip=172.17.95.1/24 --ip-masq=true --mtu=1450"
$ vi /usr/lib/systemd/system/docker.service
EnvironmentFile=/run/flannel/docker
ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock $DOCKER_NETWORK_OPTIONS
$ systemctl daemon-reload && systemctl restart docker 
$ ps -ef | grep docker
root       2588      1  1 22:09 ?        00:00:00 /usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock --bip=172.17.95.1/24 --ip-masq=true --mtu=1450
root       2724   2383  0 22:09 pts/1    00:00:00 grep --color=auto docker

6、将两台主机防火墙关闭以及iptables放通

# FORWAD 设置 ACCEPT 允许
iptables -P FORWARD ACCEPT
# iptables -I FORWARD --dst 172.17.0.0/16 -j ACCEPT

# 要先启动flanneld 再启动docker
$ systemctl restart flanneld && systemctl restart docker

7、在两台主机创建容器相互ping验证

# Docker-Node1
$ docker run -it --name busybox-node1 --hostname busybox-node1 -d busybox
/ # ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
9: eth0@if10: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1450 qdisc noqueue
    link/ether 02:42:ac:11:5c:02 brd ff:ff:ff:ff:ff:ff
    inet 172.17.92.2/24 brd 172.17.92.255 scope global eth0
       valid_lft forever preferred_lft forever
/ # ping -c 2 -W 1 172.17.95.2
PING 172.17.95.2 (172.17.95.2): 56 data bytes
64 bytes from 172.17.95.2: seq=0 ttl=62 time=1.851 ms
64 bytes from 172.17.95.2: seq=1 ttl=62 time=0.509 ms

--- 172.17.95.2 ping statistics ---
2 packets transmitted, 2 packets received, 0% packet loss
round-trip min/avg/max = 0.509/1.180/1.851 ms

# Docker-Node2
$ docker run -it --name busybox-node2 --hostname busybox-node2 -d busybox
/ # ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
9: eth0@if10: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1450 qdisc noqueue
    link/ether 02:42:ac:11:5f:02 brd ff:ff:ff:ff:ff:ff
    inet 172.17.95.2/24 brd 172.17.95.255 scope global eth0
       valid_lft forever preferred_lft forever
/ # ping -c 2 -W 1 172.17.92.2
PING 172.17.92.2 (172.17.92.2): 56 data bytes
64 bytes from 172.17.92.2: seq=0 ttl=62 time=0.493 ms
64 bytes from 172.17.92.2: seq=1 ttl=62 time=0.600 ms

--- 172.17.92.2 ping statistics ---
2 packets transmitted, 2 packets received, 0% packet loss
round-trip min/avg/max = 0.493/0.546/0.600 ms

3 容器集群管理

3.1 Docker 容器集群管理主流方案

:::color1 Docker 单个容器的部署和使用,是远远不能满足生产环境的中大型规模需要应用的。

所以管理员必须要学习容器的编排工具。例如Docker Swarm以及大名鼎鼎的 Kubernetes。

:::

Swarm、Kubernetes和Mesos介绍:

  • Swarm

Docker 公司自研发的集群管理系统。

  • Kubernetes

Google 开源的一个容器集群管理系统,用于自动化部署、扩展和管理容器应用。也称为K8S。也是Google 内部的 Borg 项目开源出来的容器编排工具项目。相对于其他的开源容器编排系统要更加的健壮。

  • Mesos

Mesos 是一个集群资源调度系统,对集群中的资源进行分配和管理Marathon 是运行在Mesos之上的一个服务管理框架,可管理容器生命周期。主要会用于大数据的容器集群管理。例如 Hadoop 集群,Spark 集群等。

Swarm、Kubernetes和Mesos简单比较:

  • 复杂性

Swarm 使用标准Docker接口,集成于Docker Engine(引擎),内置Overlay网络、服务发现、负载均衡,很容易上手,学习成本低。

K8S 成熟且复杂,自己的管理体系,服务发现,负载均衡等功能,学习成本高。得到Google,微软,RedHat,IBM等大厂的支持。K8S 是作为工业的事实标准。

Mesos 是一个成熟分布式资源管理框架,一个通用的集群管理系统。

  • 功能

Swarm 支持Docker Compose v3来实现服务编排。

K8S 强大的功能,有着一套整体容器解决方案,使用起来更轻松。

  • 社区活跃度
K8S 社区相比 Swarm 和 Mesos 活跃度都高。以及 CNCF 的支持。

3.2 Docker Swarm

3.2.1 Swarm介绍

Swarm是什么?

Swarm是Docker公司自研发的容器集群管理系统,Swarm在早期是作为一个独立服务存在,在Docker Engine v1.12中集成了Swarm的集群管理和编排功能。可以通过初始化Swarm或加入现有Swarm来启用Docker引擎的Swarm模式。

Docker Engine CLI和API包括了管理Swarm节点命令,比如添加、删除节点,以及在Swarm中部署和编排服务。

也增加了服务栈(Stack,一组服务编排的使用)、服务(Service,一个应用的抽象,一个应用可以有多个容器存在)、任务(Task,容器)概念

:::color1 Docker Swarm 几个关键字段

  1. Swarm
集群的管理和编排是使用嵌入docker引擎的SwarmKit,可以在docker初始化时启动swarm模式或者加入已存在的swarm
  1. Node
一个节点是docker引擎集群的一个实例。您还可以将其视为Docker节点。您可以在单个物理计算机或云服务器上运行一个或多个节点,但生产群集部署通常包括分布在多个物理和云计算机上的Docker节点。 要将应用程序部署到swarm,请将服务定义提交给 管理器节点。管理器节点将称为任务的工作单元分派 给工作节点。 Manager节点还执行维护所需群集状态所需的编排和集群管理功能。Manager节点选择单个领导者来执行编排任务。 工作节点接收并执行从管理器节点分派的任务。默认情况下,管理器节点还将服务作为工作节点运行,但您可以将它们配置为仅运行管理器任务并且是仅管理器节点。代理程序在每个工作程序节点上运行,并报告分配给它的任务。工作节点向管理器节点通知其分配的任务的当前状态,以便管理器可以维持每个工作者的期望状态。
  1. Service
一个服务是任务的定义,管理机或工作节点上执行。它是群体系统的中心结构,是用户与群体交互的主要根源。创建服务时,你需要指定要使用的容器镜像。
  1. Task
任务是在docekr容器中执行的命令,Manager节点根据指定数量的任务副本分配任务给worker节点

:::

Swarm两种角色:

Manager:接收客户端服务定义,将任务发送到worker节点;维护集群期望状态和集群管理功能及Leader选举。默认情况下manager节点也会运行任务,也可以配置只做管理任务。

Worker:接收并执行从管理节点分配的任务,并报告任务当前状态,以便管理节点维护每个服务期望状态。

01 Docker 进阶 %26 Kubernetes 入门 - 图25

Swarm特点:
  1. Docker Engine集成集群管理
使用Docker Engine CLI创建一个Docker Engine的Swarm模式,在集群中部署应用程序服务。
  1. 去中心化设计
Swarm角色分为Manager和Worker节点,Manager节点故障不影响应用使用。
  1. 扩容缩容
可以声明每个服务运行的容器数量,通过添加或删除容器数自动调整期望的状态。
  1. 期望状态协调
Swarm Manager节点不断监视集群状态,并调整当前状态与期望状态之间的差异。例如,设置一个服务运行10个副本容器,如果两个副本的服务器节点崩溃,Manager将创建两个新的副本替代崩溃的副本。并将新的副本分配到可用的worker节点。
  1. 多主机网络
可以为服务指定overlay网络。当初始化或更新应用程序时,Swarm manager会自动为overlay网络上的容器分配IP地址。
  1. 服务发现
Swarm manager节点为集群中的每个服务分配唯一的DNS记录和负载均衡VIP。可以通过Swarm内置的DNS服务器查询集群中每个运行的容器。
  1. 负载均衡
实现服务副本负载均衡,提供入口访问。也可以将服务入口暴露给外部负载均衡器再次负载均衡。
  1. 安全传输
Swarm中的每个节点使用TLS相互验证和加密,确保安全的其他节点通信。
  1. 滚动更新
升级时,逐步将应用服务更新到节点,如果出现问题,可以将任务回滚到先前版本。

3.2.2 集群部署及节点管理

使用swarm前提:

  • Docker版本1.12+
  • 集群节点之间保证TCP 2377、TCP/UDP 7946 和 UDP4789端口通信

节点规划:

操作系统:Ubuntu 20.04_x64

管理节点:10.0.0.100 [ 主机名:swarm-master ]

工作节点:10.0.0.101 [ 主机名:swarm-worker01 ]

工作节点:10.0.0.102 [ 主机名:swarm-worker02 ]

安装Docker

cat > ubuntu-install-docker.sh <<-'END'
# step 1: 安装必要的一些系统工具
sudo apt-get update
sudo apt-get -y install apt-transport-https ca-certificates curl software-properties-common

# step 2: 安装GPG证书
curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -

# Step 3: 写入软件源信息
sudo add-apt-repository "deb [arch=amd64] https://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable"

# Step 4: 更新并安装Docker-CE
sudo apt-get -y update
sudo apt-get -y install docker-ce

# Step 5: Docker加速器配置以及优化
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://po13h3y1.mirror.aliyuncs.com","http://hub-mirror.c.163.com","https://mirror.ccs.tencentyun.com","http://f1361db2.m.daocloud.io"],
  "exec-opts": ["native.cgroupdriver=systemd"],
  "log-driver": "json-file",
  "log-opts": {
    "max-size": "100m"
  },
  "storage-driver": "overlay2"
}
EOF

sudo systemctl daemon-reload && sudo systemctl restart docker

# Step 6: Docker信息
docker info
END

sudo chmod +x ubuntu-install-docker.sh && bash ubuntu-install-docker.sh

管理节点初始化swarm master:

$ docker swarm init --advertise-addr 10.0.0.100

01 Docker 进阶 %26 Kubernetes 入门 - 图26

工作节点加入swarm worker:

$ docker swarm join --token SWMTKN-1-5bv8t5swpnxy6vhnf244dxd8bdgokfhdg686lo69o1fntzb1lt-eckvfp6lh1ysykflkv3eteztw 10.0.0.100:2377

01 Docker 进阶 %26 Kubernetes 入门 - 图27

管理节点查看节点信息

$ docker node ls 
ID                            HOSTNAME         STATUS    AVAILABILITY   MANAGER STATUS   ENGINE VERSION
ah1qkwni3gm1ifh5g20e9890i *   swarm-master     Ready     Active         Leader           20.10.21
r3rcx30cg5nhdhnt1c1ucw579     swarm-worker01   Ready     Active                          20.10.21
rciafdim7e47siyfew1zbezv6     swarm-worker02   Ready     Active                          20.10.21

# 查看节点的帮助文档
$ docker node --help 

Usage:  docker node COMMAND

Manage Swarm nodes

Commands:
  demote      Demote one or more nodes from manager in the swarm 从群集管理器中降级一个或多个节点
  inspect     Display detailed information on one or more nodes  显示一个或多个节点的详细信息
  ls          List nodes in the swarm 列出集群中的节点
  promote     Promote one or more nodes to manager in the swarm  将群集中的一个或多个节点提升为manager
  ps          List tasks running on one or more nodes, defaults to current node 列出在一个或多个节点上运行的任务,默认为当前节点
  rm          Remove one or more nodes from the swarm 从群集中移除一个或多个节点
  update      Update a node 更新节点

$ docker node inspect          swarm-master
$ docker node inspect --pretty swarm-master

01 Docker 进阶 %26 Kubernetes 入门 - 图28

3.2.3 服务管理

3.2.3.1 服务管理基本使用

# 创建服务
docker service create --replicas 1 --name hello-busybox busybox

# 显示服务详细信息
# 易于阅读显示
docker service inspect --pretty hello 
# json格式返回
docker service inspect hello

# 扩展服务实例数
docker service scale hello=3

# 查看服务任务
docker service ls
docker service ps hello
docker service ps -f 'desired-state=running' hello

# 滚动更新服务
docker service create \
--replicas 3 \
--name redis \
--update-delay 10s \
redis:3.0.6

# 升级镜像
docker service update --image redis:3.0.7 redis

范例:

# 创建服务
$ docker service create --replicas 1 --name hello-busybox busybox
$ docker service ls 
ID             NAME            MODE         REPLICAS   IMAGE            PORTS
ua0v12k7y43b   hello-busybox   replicated   0/1        busybox:latest   

# 更新服务的配置
$ docker service update --args "ping www.baidu.com" hello-busybox 
hello-busybox
overall progress: 1 out of 1 tasks 
1/1: running   [==================================================>] 
verify: Service converged
$ docker service ls 
ID             NAME            MODE         REPLICAS   IMAGE            PORTS
ua0v12k7y43b   hello-busybox   replicated   1/1        busybox:latest   
$ docker service ps hello-busybox 
ID             NAME                  IMAGE            NODE             DESIRED STATE   CURRENT STATE             ERROR     PORTS
peivgy10oes8   hello-busybox.1       busybox:latest   swarm-master     Running         Running 32 seconds ago              
c09j0tic7czv    \_ hello-busybox.1   busybox:latest   swarm-master     Shutdown        Shutdown 32 seconds ago             
cyme0l3uhw3g    \_ hello-busybox.1   busybox:latest   swarm-worker01   Shutdown        Complete 37 seconds ago             
pxolzmjrqwl6    \_ hello-busybox.1   busybox:latest   swarm-worker01   Shutdown        Complete 43 seconds ago             
nityzaqluufj    \_ hello-busybox.1   busybox:latest   swarm-worker01   Shutdown        Complete 49 seconds ago   

# 过滤相应的信息
$ docker service ps -f "DESIRED-STATE=Running" hello-busybox 
ID             NAME              IMAGE            NODE           DESIRED STATE   CURRENT STATE                ERROR     PORTS
peivgy10oes8   hello-busybox.1   busybox:latest   swarm-master   Running         Running about a minute ago       
$ docker ps 
CONTAINER ID   IMAGE            COMMAND                CREATED         STATUS         PORTS     NAMES
df1622c9e920   busybox:latest   "ping www.baidu.com"   2 minutes ago   Up 2 minutes             hello-busybox.1.peivgy10oes8dj4jmdra0w5tl

# 扩展服务实例数
$ docker service scale hello-busybox=3
hello-busybox scaled to 3
overall progress: 3 out of 3 tasks 
1/3: running   [==================================================>] 
2/3: running   [==================================================>] 
3/3: running   [==================================================>] 
verify: Service converged 
$ docker service ps -f "DESIRED-STATE=Running" hello-busybox 
ID             NAME              IMAGE            NODE             DESIRED STATE   CURRENT STATE            ERROR     PORTS
peivgy10oes8   hello-busybox.1   busybox:latest   swarm-master     Running         Running 3 minutes ago              
ni18elvgyds5   hello-busybox.2   busybox:latest   swarm-worker01   Running         Running 41 seconds ago             
wpqqguxkxjbn   hello-busybox.3   busybox:latest   swarm-worker02   Running         Running 41 seconds ago        
# 默认情况下swarm-master也会创建服务

# 将swarm-master打上污点
$ docker node update --availability drain swarm-master
$ docker service ls 
ID             NAME            MODE         REPLICAS   IMAGE            PORTS
ua0v12k7y43b   hello-busybox   replicated   3/3        busybox:latest   
$ docker service ps -f "DESIRED-STATE=Running" hello-busybox 
ID             NAME              IMAGE            NODE             DESIRED STATE   CURRENT STATE            ERROR     PORTS
jii2n1657kw6   hello-busybox.1   busybox:latest   swarm-worker01   Running         Running 37 seconds ago             
ni18elvgyds5   hello-busybox.2   busybox:latest   swarm-worker01   Running         Running 3 minutes ago              
wpqqguxkxjbn   hello-busybox.3   busybox:latest   swarm-worker02   Running         Running 3 minutes ago  
# 而 swarm-master 则无法分配到应用容器

# 滚动更新服务
$ docker service create \
--replicas 3 \
--name redis \
--update-delay 10s \
redis:3.0.6
$ docker service ps redis 
ID             NAME      IMAGE         NODE             DESIRED STATE   CURRENT STATE            ERROR     PORTS
vha98sr3p7ex   redis.1   redis:3.0.6   swarm-worker01   Running         Running 58 seconds ago             
0hpk83mr3nul   redis.2   redis:3.0.6   swarm-worker02   Running         Running 54 seconds ago             
s87wmf6xtg6a   redis.3   redis:3.0.6   swarm-worker02   Running         Running 54 seconds ago  

# 升级镜像
docker service update --image redis:3.0.7 redis

3.2.3.2 服务管理策略

# 创建服务时设定更新策略
$ docker service create \
--name my_web \
--replicas 10 \
--update-delay 10s \
--update-parallelism 2 \
--update-failure-action continue \
nginx:1.12
$ docker service ps my_web 
ID             NAME        IMAGE        NODE             DESIRED STATE   CURRENT STATE            ERROR     PORTS
uoneffutwe8n   my_web.1    nginx:1.12   swarm-worker02   Running         Running 24 seconds ago             
pldijh5geilr   my_web.2    nginx:1.12   swarm-worker02   Running         Running 25 seconds ago             
s44chyjl789r   my_web.3    nginx:1.12   swarm-worker02   Running         Running 25 seconds ago             
4uc8hjr5b2ze   my_web.4    nginx:1.12   swarm-worker01   Running         Running 25 seconds ago             
oiv25n2f0t07   my_web.5    nginx:1.12   swarm-worker02   Running         Running 25 seconds ago             
sbidqlzlumnd   my_web.6    nginx:1.12   swarm-worker01   Running         Running 25 seconds ago             
2aah8g3h30z9   my_web.7    nginx:1.12   swarm-worker01   Running         Running 25 seconds ago             
kbsgh6012jl3   my_web.8    nginx:1.12   swarm-worker01   Running         Running 25 seconds ago             
oiv6zldxqso7   my_web.9    nginx:1.12   swarm-worker01   Running         Running 25 seconds ago             
84ldttb6em5k   my_web.10   nginx:1.12   swarm-worker02   Running         Running 25 seconds ago             

# 创建服务时设定回滚策略
$ docker service create \
--name my_web_rollback \
--replicas 10 \
--rollback-parallelism 2 \
--rollback-monitor 20s \
--rollback-max-failure-ratio .2 \
nginx:1.12

# 服务更新
$ docker service update --image nginx:1.13 my_web
$ docker service ps my_web 
ID             NAME            IMAGE        NODE             DESIRED STATE   CURRENT STATE                 ERROR     PORTS
p0z4hn2c0ruy   my_web.1        nginx:1.13   swarm-worker02   Running         Running about a minute ago              
uoneffutwe8n    \_ my_web.1    nginx:1.12   swarm-worker02   Shutdown        Shutdown about a minute ago             
2rhl75nhjgc5   my_web.2        nginx:1.13   swarm-worker02   Running         Running about a minute ago              
pldijh5geilr    \_ my_web.2    nginx:1.12   swarm-worker02   Shutdown        Shutdown about a minute ago             
c11h96565wgm   my_web.3        nginx:1.13   swarm-worker02   Running         Running 59 seconds ago                  
s44chyjl789r    \_ my_web.3    nginx:1.12   swarm-worker02   Shutdown        Shutdown 59 seconds ago                 
l024dcmzyvut   my_web.4        nginx:1.13   swarm-worker02   Running         Running about a minute ago              
4uc8hjr5b2ze    \_ my_web.4    nginx:1.12   swarm-worker01   Shutdown        Shutdown about a minute ago             
o4kipl10wd32   my_web.5        nginx:1.13   swarm-worker02   Running         Running about a minute ago              
oiv25n2f0t07    \_ my_web.5    nginx:1.12   swarm-worker02   Shutdown        Shutdown about a minute ago             
jrrb0u2etzgp   my_web.6        nginx:1.13   swarm-worker01   Running         Running 46 seconds ago                  
sbidqlzlumnd    \_ my_web.6    nginx:1.12   swarm-worker01   Shutdown        Shutdown 47 seconds ago                 
cs7z42v28r49   my_web.7        nginx:1.13   swarm-worker01   Running         Running 59 seconds ago                  
2aah8g3h30z9    \_ my_web.7    nginx:1.12   swarm-worker01   Shutdown        Shutdown 59 seconds ago                 
21lhk6wfdnvz   my_web.8        nginx:1.13   swarm-worker01   Running         Running 46 seconds ago                  
kbsgh6012jl3    \_ my_web.8    nginx:1.12   swarm-worker01   Shutdown        Shutdown 47 seconds ago                 
4rp1z6jxyeqw   my_web.9        nginx:1.13   swarm-worker01   Running         Running about a minute ago              
oiv6zldxqso7    \_ my_web.9    nginx:1.12   swarm-worker01   Shutdown        Shutdown about a minute ago             
tvautqpxj928   my_web.10       nginx:1.13   swarm-worker01   Running         Running about a minute ago              
84ldttb6em5k    \_ my_web.10   nginx:1.12   swarm-worker02   Shutdown        Shutdown about a minute ago  

# 手动回滚(先升级后回滚)
$ docker service update --image nginx:1.16 my_web_rollback
$ docker service ps -f "DESIRED-STATE=Running" my_web_rollback 
ID             NAME                 IMAGE        NODE             DESIRED STATE   CURRENT STATE           ERROR     PORTS
dpd3xn6izbiv   my_web_rollback.1    nginx:1.16   swarm-worker01   Running         Running 9 minutes ago             
yi9fe0o3gvb1   my_web_rollback.2    nginx:1.16   swarm-worker01   Running         Running 9 minutes ago             
usw0r797qo1g   my_web_rollback.3    nginx:1.16   swarm-worker02   Running         Running 9 minutes ago             
oyhsfc2hlx85   my_web_rollback.4    nginx:1.16   swarm-worker02   Running         Running 9 minutes ago             
1zbhj4xvtxzn   my_web_rollback.5    nginx:1.16   swarm-worker01   Running         Running 9 minutes ago             
p0dj8puwvpgd   my_web_rollback.6    nginx:1.16   swarm-worker02   Running         Running 9 minutes ago             
me5ws38tkmol   my_web_rollback.7    nginx:1.16   swarm-worker02   Running         Running 9 minutes ago             
6uj7api464do   my_web_rollback.8    nginx:1.16   swarm-worker01   Running         Running 9 minutes ago             
1dnstvo2xbqd   my_web_rollback.9    nginx:1.16   swarm-worker02   Running         Running 9 minutes ago             
f6ke6b20b7m7   my_web_rollback.10   nginx:1.16   swarm-worker01   Running         Running 9 minutes ago  

$ docker service rollback my_web_rollback
$ docker service update --rollback my_web_rollback

3.2.4 使用原生Overlay网络

# 创建overlay网络
$ docker network create --driver overlay my-network

# 创建新服务并使用overlay网络
$ docker service create \
--replicas 3 \
--network my-network \
--name my-web \
nginx:1.23.2-alpine
$ docker service ps my-web 
ID             NAME       IMAGE                 NODE             DESIRED STATE   CURRENT STATE            ERROR     PORTS
i25zts4m915t   my-web.1   nginx:1.23.2-alpine   swarm-worker01   Running         Running 19 seconds ago             
4upacvdjpxig   my-web.2   nginx:1.23.2-alpine   swarm-worker01   Running         Running 9 seconds ago              
prfj7ppdym5e   my-web.3   nginx:1.23.2-alpine   swarm-worker02   Running         Running 20 seconds ago      

# 将现有服务连接到overlay网络
$ docker service update --network-add my-network my-web

# 删除正在运行的服务网络连接
$ docker service update --network-rm my-network my-web

# 测试Overlay网络的连通性
# swarm-worker01 执行进入服务容器
$ docker exec -it my-web.1.i25zts4m915t73v3vqz63ezte sh
/ # ip addr 
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
86: eth0@if87: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1450 qdisc noqueue state UP 
    link/ether 02:42:0a:00:01:09 brd ff:ff:ff:ff:ff:ff
    inet 10.0.1.9/24 brd 10.0.1.255 scope global eth0
       valid_lft forever preferred_lft forever
88: eth1@if89: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1500 qdisc noqueue state UP 
    link/ether 02:42:ac:12:00:03 brd ff:ff:ff:ff:ff:ff
    inet 172.18.0.3/16 brd 172.18.255.255 scope global eth1
       valid_lft forever preferred_lft forever
/ # ping -c 1 -W 1 10.0.1.11
PING 10.0.1.11 (10.0.1.11): 56 data bytes
64 bytes from 10.0.1.11: seq=0 ttl=64 time=1.233 ms

--- 10.0.1.11 ping statistics ---
1 packets transmitted, 1 packets received, 0% packet loss
round-trip min/avg/max = 1.233/1.233/1.233 ms
/ # nslookup my-web
Server:         127.0.0.11
Address:        127.0.0.11:53

** server can't find my-web.Ubuntu2004-cluster02: NXDOMAIN

** server can't find my-web.Ubuntu2004-cluster02: NXDOMAIN
/ # ping -c 1 -W 1 my-web
PING my-web (10.0.1.8): 56 data bytes
64 bytes from 10.0.1.8: seq=0 ttl=64 time=0.155 ms

--- my-web ping statistics ---
1 packets transmitted, 1 packets received, 0% packet loss
round-trip min/avg/max = 0.155/0.155/0.155 ms

# swarm-worker02 执行进入服务容器
$ docker exec -it my-web.3.prfj7ppdym5ec9j1gk9d405n1 sh
/ # ip addr 
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
94: eth0@if95: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1450 qdisc noqueue state UP 
    link/ether 02:42:0a:00:01:0b brd ff:ff:ff:ff:ff:ff
    inet 10.0.1.11/24 brd 10.0.1.255 scope global eth0
       valid_lft forever preferred_lft forever
96: eth1@if97: <BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN> mtu 1500 qdisc noqueue state UP 
    link/ether 02:42:ac:12:00:03 brd ff:ff:ff:ff:ff:ff
    inet 172.18.0.3/16 brd 172.18.255.255 scope global eth1
       valid_lft forever preferred_lft forever

3.2.5 数据持久化

3.2.5.1 volume

01 Docker 进阶 %26 Kubernetes 入门 - 图29

# 创建数据卷
docker service create \
--mount type=volume, src=<VOLUME一NAME>, dst=<CONTAINER-PATH> \
--name myservice \
<IMAGE>

# 查看数据卷详细信息
docker volume inspect <VOLUME-NAME>

# 使用NFS共享存储作为数据卷
docker service create \
--mount 'type=volume, src=<VOLUME-NAME>, dst=<CONTAINER-PATH>, volume-driver=local, volume-opt=type=nfs, volume-opt=device=<nfs-server>:<nfs-path>, "volume-opt=o=addr=<nfs-address>, vers=4, soft, timeo=180, bg,tcp,rw"' \
-—name myservice \
<IMAGE>

范例:

$ docker service create --mount type=volume,src=test,dst=/data --name nginx-node nginx:1.23.2-alpine
$ docker service ls 
ID             NAME         MODE         REPLICAS   IMAGE                 PORTS
d0birwhza8al   nginx-node   replicated   1/1        nginx:1.23.2-alpine   
$ docker service ps nginx-node
ID             NAME           IMAGE                 NODE             DESIRED STATE   CURRENT STATE            ERROR     PORTS
xko93ap3b5x6   nginx-node.1   nginx:1.23.2-alpine   swarm-worker02   Running         Running 33 seconds ago          

# 查看数据卷信息
$ docker volume ls 
DRIVER    VOLUME NAME
local     test
$ docker volume inspect -f "{{.Mountpoint}}" test 
/var/lib/docker/volumes/test/_data
$ echo "Hello Volume Manager" > /var/lib/docker/volumes/test/_data/volume1.txt
# 单个服务的单个容器可以使用其数据卷,但数据的同步无法通过Docker实现
$ docker exec -it nginx-node.1.xko93ap3b5x6u8yj2d2zm45gd sh 
/ # cat /data/volume1.txt 
Hello Volume Manager

####################################################################################################################################
# 使用NFS共享存储作为数据卷(服务器端执行)
$ sudo apt-get update && sudo apt-get install -y nfs-kernel-server 
$ ps -ef | grep nfs 
root       68019       2  0 04:52 ?        00:00:00 [nfsd]
root       68020       2  0 04:52 ?        00:00:00 [nfsd]
root       68021       2  0 04:52 ?        00:00:00 [nfsd]
root       68022       2  0 04:52 ?        00:00:00 [nfsd]
root       68023       2  0 04:52 ?        00:00:00 [nfsd]
root       68024       2  0 04:52 ?        00:00:00 [nfsd]
root       68025       2  0 04:52 ?        00:00:00 [nfsd]
root       68026       2  0 04:52 ?        00:00:00 [nfsd]
root       68548   54171  0 04:55 pts/1    00:00:00 grep --color=auto nfs

$ mkdir -pv /opt/docker/wwwroot && chmod 777 -R /opt/docker/
$ cat > /etc/exports <<EOF
/opt/docker/wwwroot 10.0.0.100/24(rw)
EOF
$ systemctl restart nfs-kernel-server.service 

# 使用NFS共享存储作为数据卷(所有客户端执行)
$ sudo apt-get update && sudo apt-get install -y nfs-common
$ mkdir -pv /mnt/nfs
$ mount -t nfs 10.0.0.100:/opt/docker/wwwroot /mnt/nfs

# 创建相应的服务(使用NFS)
# --name,指定名字
# source=nfsvolume  docker宿主机上的卷的名字,若是没有可以自己创建,按自己的修改。另外这个卷名字只能使用一次
# /app  容器里存放网页的目录,按自己的修改
# volume-driver=local  访问本地的某个目录
# volume-opt=type=nfs  volume对nfs的支持选项
# volume-opt=device=:/var/docker-nfs  是nfs服务器共享的目录
# volume-opt=o=addr=10.0.0.10,rw,nfsvers=4,async  挂载具体的nfs服务器的IP地址和选项
# --replicas 10 副本数量
# -p 10880:80   映射端口
$ docker service create -d \
--mount 'type=volume,src=nfs-test,dst=/usr/share/nginx/html,volume-driver=local,volume-driver=local,volume-opt=type=nfs,volume-opt=device=10.0.0.100:/opt/docker/wwwroot,"volume-opt=o=addr=10.0.0.100,async,nfsvers=4,soft,timeo=180,bg,rw"' \
-p 10880:80 --name my-web-nginx nginx:1.23.2-alpine
$ docker service ps -f "DESIRED-STATE=Running" my-web-nginx 
ID             NAME             IMAGE                 NODE             DESIRED STATE   CURRENT STATE           ERROR     PORTS
rma0xtw4fx80   my-web-nginx.1   nginx:1.23.2-alpine   swarm-worker02   Running         Running 5 minutes ago    

$ echo "Hello Docker Volume Page" > /var/lib/docker/volumes/nfs-test/_data/index.html
$ curl 10.0.0.100:10880
Hello Docker Volume Page

:::color1 注意:若提示报错”failed to chmod on /var/lib/docker/volumes/nfs-test/_data: chmod /var/lib/docker/volumes/nfs-test/_data: operation not permitted“类似的提示

解决方法:将NFS的目录的权限提高即可。

:::

3.2.5.2 bind

# 读写挂载
docker service create \
--mount type=bind,src=<HOST-PATH>,dst=<CONTAINER-PATH> \
--name myservice \
<IMAGE>

# 只读挂载
docker service create \
—-mount type=bind,src=<HOST-PATH>,dst=<CONTAINER-PATH>, readonly \
--name myservice \
<IMAGE>

范例:

# 创建Nginx Docker服务
$ docker service create \
--mount type=bind,src=/etc,dst=/data \
--name nginx-bind --replicas 1 \
nginx:1.23.2-alpine

# 进入到容器中
$ docker service ls 
ID             NAME           MODE         REPLICAS   IMAGE                 PORTS
jeuctc1y15r1   nginx-bind     replicated   1/1        nginx:1.23.2-alpine
$ docker service ps nginx-bind 
ID             NAME           IMAGE                 NODE             DESIRED STATE   CURRENT STATE                ERROR     PORTS
vrr7fizhf1vz   nginx-bind.1   nginx:1.23.2-alpine   swarm-worker01   Running         Running about a minute ago      

# 可以显示出宿主机/etc/目录的文件列表
$ docker exec -it nginx-bind.1.vrr7fizhf1vzqjjy0v7f2298y ls /data/
$ docker service inspect --pretty nginx-bind | grep -A 4 Mounts
Mounts:
 Target:        /data
  Source:       /etc
  ReadOnly:     false
  Type:         bind

:::color1 使用 bind 数据持久化,就必须要确保宿主机要有该目录才行,否则会挂载失败的!

在某些场景下会使用到 bind 的数据持久化方式。

:::

3.2.6 服务发现与负载均衡

3.2.6.0 服务发现与负载均衡介绍

01 Docker 进阶 %26 Kubernetes 入门 - 图30

Swarm模式内置DNS组件,可以自动为集群中的每个服务分配DNS记录。Swarm manager使用内部负载均衡,根据服务的DNS名称在集群内的服务之间分发请求。

Swarm manager使用ingress load blancing暴露你想从外部访问集群提供的服务。Swarm manager自动为服务分配一个范围30000-32767端口的Published Port,也可以为该服务指定一个Published Port。

ingress network是一个特殊的overlay网络,便于服务的节点直接负载均衡。当任何swarm节点在已发布的端口上接收到请求时,它将该请求转发给调用的IPVS模块,IPVS跟踪参与该服务的所有IP地址,选择其中一个,并通过ingress network将请求路由给它。

3.2.6.1 服务发现与负载均衡实验

范例:

# 进容器查看DNS记录
$ docker network create -d overlay --subnet 192.168.0.0/24 --gateway 192.168.0.1 my-overlay
$ docker service create --replicas 3 --network my-overlay --name my-web nginx:1.23.2-alpine
$ docker service create --replicas 3 --network my-overlay --name hello busybox ping www.baidu.com

$ docker service ps my-web
ID             NAME       IMAGE                 NODE             DESIRED STATE   CURRENT STATE           ERROR     PORTS
jo5w1y32aptn   my-web.1   nginx:1.23.2-alpine   swarm-worker02   Running         Running 4 minutes ago             
8v6071iovins   my-web.2   nginx:1.23.2-alpine   swarm-worker01   Running         Running 4 minutes ago             
xu6ly9m6uqtr   my-web.3   nginx:1.23.2-alpine   swarm-worker02   Running         Running 4 minutes ago     
$ docker service ps hello 
ID             NAME      IMAGE            NODE             DESIRED STATE   CURRENT STATE                ERROR     PORTS
1c5171r4q6bm   hello.1   busybox:latest   swarm-worker01   Running         Running about a minute ago             
2vu89apgxyn3   hello.2   busybox:latest   swarm-worker01   Running         Running about a minute ago             
wu1punud56gi   hello.3   busybox:latest   swarm-worker02   Running         Running about a minute ago    

$ docker exec -it hello.3.wu1punud56gisbyrdt1nnwqlj sh
/ # nslookup my-web
Server:         114.114.114.114
Address:        114.114.114.114:53

** server can't find nginx-bind.Ubuntu2004-cluster02: NXDOMAIN
** server can't find nginx-bind.Ubuntu2004-cluster02: NXDOMAIN

$ / # wget my-web 
Connecting to my-web (192.168.0.2:80)
saving to 'index.html'
index.html           100% |******************************************************************************************|   615  0:00:00 ETA
'index.html' saved
/ # cat index.html 
<!DOCTYPE html>
<html>
<head>
<title>Welcome to nginx!</title>
<style>
html { color-scheme: light dark; }
body { width: 35em; margin: 0 auto;
font-family: Tahoma, Verdana, Arial, sans-serif; }
</style>
</head>
<body>
<h1>Welcome to nginx!</h1>
<p>If you see this page, the nginx web server is successfully installed and
working. Further configuration is required.</p>

<p>For online documentation and support please refer to
<a href="http://nginx.org/">nginx.org</a>.<br/>
Commercial support is available at
<a href="http://nginx.com/">nginx.com</a>.</p>

<p><em>Thank you for using nginx.</em></p>
</body>

# 获取虚拟IP
$ docker service inspect -f '{{json. Endpoint.VirtualIPs}}' hello
$ docker service inspect -f '{{json .Endpoint.VirtualIPs}}' hello
[{"NetworkID":"g2qgbs0pbdmiiv7czc20ismda","Addr":"192.168.0.8/24"}]

# 将服务设置暴露端口
$ docker service update --publish-add 10990:80 my-web
# 再使用浏览器访问Docker Swarm节点的10990就可以访问到后端的 my-web 的服务
$ curl 10.0.0.100:10990
<!DOCTYPE html>
<html>
<head>
<title>Welcome to nginx!</title>
<style>
html { color-scheme: light dark; }
body { width: 35em; margin: 0 auto;
font-family: Tahoma, Verdana, Arial, sans-serif; }
</style>
</head>
<body>
<h1>Welcome to nginx!</h1>
<p>If you see this page, the nginx web server is successfully installed and
working. Further configuration is required.</p>

<p>For online documentation and support please refer to
<a href="http://nginx.org/">nginx.org</a>.<br/>
Commercial support is available at
<a href="http://nginx.com/">nginx.com</a>.</p>

<p><em>Thank you for using nginx.</em></p>
</body>
</html>

# 查看服务的服务模式
$ docker service inspect -f "{{.PreviousSpec.EndpointSpec.Mode}}" my-web
vip

范例:设置DNS轮询模式

# 设置DNS轮询模式
$ docker service create \
  --replicas 3 \
  --name my-web-dnsrr \
  --network my-network \
  --endpoint-mode dnsrr \
  nginx:1.23.2-alpine

# 使用DNS轮询模式则不能使用指定端口
# 来自守护进程的错误响应:rpc Error: code = InvalidArgument desc = EndpointSpec:以入口模式发布的端口不能与dnsrr模式一起使用

01 Docker 进阶 %26 Kubernetes 入门 - 图31

3.2.6.2 服务发现和负载均衡网络结构图

01 Docker 进阶 %26 Kubernetes 入门 - 图32

基于DNS的负载均衡

DNS server 内嵌于Docker 引擎。下面创建两个基于DNS负载均衡服务:客户端client和服务端vote, 服务间通过服务名进行调用通信。 Docker DNS 解析服务名”vote” 并返回容器ID地址列表(随机排序)。客户端通常会挑第一个IP访问,因此负载均衡可能发生在不同实例之间。

01 Docker 进阶 %26 Kubernetes 入门 - 图33

基于VIP(Virtual IP)的负载均衡

基于VIP的负载均衡克服了基于DNS负载均衡的一些问题。在这种方法中,每个服务都有一个虚拟IP地址,并且该IP地址映射到与该服务关联的多个容器的IP地址。在这种情况下,与服务关联的服务IP不会改变,即使与改服务关联的容器死亡并重新启动。
01 Docker 进阶 %26 Kubernetes 入门 - 图34 路由网络(Routing Mesh) 使用路由网络,服务暴露的端口会暴露在集群中的所有的工作节点。Docker 是通过创建“ingress overlay”网络来实现这一点的,所有节点默认使用内在sandbox 网络命名空间成为“ingress” overlay网络的一部分。 01 Docker 进阶 %26 Kubernetes 入门 - 图35 首先,会将Hostname或IP映射到Sandbox IP,Sandbox中的 iptables 和 IPVS 负责将请求负载均衡到2个vote_Routing 容器,Ingress Sandbox网络命名空间驻留在 Docker Swarm 集群中的所有工作节点,它通过主机映射的端口负载均衡到后端容器来协助路由网格功能。 ### 3.2.7 高可用性 #### 3.2.7.1 高可用 01 Docker 进阶 %26 Kubernetes 入门 - 图36 Manager节点任务: 1. 维护集群状态 2. 调度服务 3. 提供swarm模式的HTTP API | Swarm Size | Majority | Fault Toleranoe | | —- | —- | —- | | 1 | 1 | 0 | | 2 | 2 | 0 | | 3 | 2 | 1 | | 4 | 3 | 1 | | 5 | 3 | 2 | | 6 | 4 | 2 | | 7 | 4 | 3 | | 8 | 5 | 3 | | 9 | 5 | 4 | 为了利用swarm模式的容错功能,应保持集群中奇数管理员来支持manager节点故障。当leader故障时,会选举新的leader。 #### 3.2.7.2 故障恢复 如果swarm失去法定人数,swarm不能自动恢复,工作节点上的任务继续运行,不受影响,但无法执行管理任务,包括扩展或更新服务,加入或删除节点。恢复的最佳方式是将丢失的leader节点重新联机。如果不可能,唯一方法是使用一force-new-cluster管理节点的操作,这将去除本机之外的所有管理器身份。 bash docker swarm init --force-new-cluster --advertise-addr 10.0.0.100:2377 #### 3.2.7.3 Docker swarm Token 的使用 bash $ docker swarm join-token --help Usage: docker swarm join-token [OPTIONS] (worker|manager) Manage join tokens Options: -q, --quiet Only display token --rotate Rotate join token $ docker swarm join-token worker To add a worker to this swarm, run the following command: docker swarm join --token SWMTKN-1-5bv8t5swpnxy6vhnf244dxd8bdgokfhdg686lo69o1fntzb1lt-eckvfp6lh1ysykflkv3eteztw 10.0.0.100:2377 $ docker swarm join-token manager To add a manager to this swarm, run the following command: docker swarm join --token SWMTKN-1-5bv8t5swpnxy6vhnf244dxd8bdgokfhdg686lo69o1fntzb1lt-03cuo2nfrj5o8daa8d2ziicl8 10.0.0.100:2377 01 Docker 进阶 %26 Kubernetes 入门 - 图37 #### 3.2.7.4 手动提升或者降级节点的角色 bash # 将群集中的一个或多个节点提升为manager $ docker node promote swarm-worker01 $ docker node ls ID HOSTNAME STATUS AVAILABILITY MANAGER STATUS ENGINE VERSION ah1qkwni3gm1ifh5g20e9890i * swarm-master Ready Drain Leader 20.10.21 r3rcx30cg5nhdhnt1c1ucw579 swarm-worker01 Ready Active Reachable 20.10.21 rciafdim7e47siyfew1zbezv6 swarm-worker02 Ready Active 20.10.21 $ docker node promote swarm-worker02 $ docker node ls ID HOSTNAME STATUS AVAILABILITY MANAGER STATUS ENGINE VERSION ah1qkwni3gm1ifh5g20e9890i * swarm-master Ready Drain Leader 20.10.21 r3rcx30cg5nhdhnt1c1ucw579 swarm-worker01 Ready Active Reachable 20.10.21 rciafdim7e47siyfew1zbezv6 swarm-worker02 Ready Active Reachable 20.10.21 # 将swarm-master的Docker Service停止 $ systemctl stop docker $ docker node ls ID HOSTNAME STATUS AVAILABILITY MANAGER STATUS ENGINE VERSION ah1qkwni3gm1ifh5g20e9890i swarm-master Unknown Drain Unreachable 20.10.21 r3rcx30cg5nhdhnt1c1ucw579 swarm-worker01 Ready Active Reachable 20.10.21 rciafdim7e47siyfew1zbezv6 * swarm-worker02 Ready Active Leader 20.10.21 # 从群集管理器中降级一个或多个节点 $ docker node demote swarm-worker01 bash #以管理节点角色加入swarm docker swarm join-token manager #在管理节点手动改变角色 docker node promote <NAME> docker node demote <NAME> #在管理节点查看角色 docker node ls ### 3.2.8 配置文件存储 在集群环境中配置文件的分发,可以通过将配置文件放入镜像中、设置环境变量、挂载volume、挂载目录的方式,当然也可以通过 docker config 来管理集群中的配置文件,这样的方式也更加通用。

3.2.8.1 生成一个基本的Nginx配置文件

$ cat > site.conf <<EOF
server {
  listen 80;
  server_name localhost;
  location / {
    root  /usr/share/nginx/html;
    index index.html index.htm;
  }
}
EOF

3.2.8.2 将site.conf保存到docker配置中

$ docker config create site.conf site.conf

$ docker config ls
ID                          NAME        CREATED         UPDATED
o80pb4g6drlbs6eskz6xo0aja   site.conf   4 seconds ago   4 seconds ago

3.2.8.3 创建一个Nginx并应用这个配置

$ docker service create \
--name nginx \
--config source=site.conf,target=/etc/nginx/conf.d/site.conf \
--publish 8080:80 \
nginx:1.23.2-alpine

$ docker service ps nginx
ID             NAME      IMAGE                 NODE             DESIRED STATE   CURRENT STATE                ERROR     PORTS
lyy5cfkelrwg   nginx.1   nginx:1.23.2-alpine   swarm-worker01   Running         Running about a minute ago 
$ docker exec -it nginx.1.lyy5cfkelrwgad0i5g47o4vx9 /bin/sh
/ # cat /etc/nginx/conf.d/site.conf
server {
  listen 80;
  server_name localhost;
  location / {
    root  /usr/share/nginx/html;
    index index.html index.htm;
  }
}
# 可以查看到该配置文件可以被应用到

3.2.9 应用实战

3.2.9.1 搭建私有镜像仓库

  • 下载镜像 Docker Registry
$ docker pull registry
$ docker images registry
REPOSITORY   TAG       IMAGE ID       CREATED         SIZE
registry     latest    b8604a3fe854   12 months ago   26.2MB
  • 运行私有库 Registry,相当于本地有个私有Docker Hub
$ mkdir -pv /app/registry
$ docker run -d -p 5000:5000 \
  -v /app/registry:/tmp/registry \
  --privileged=true \
  --name myregistry \
  --restart=always registry

$ docker ps -l
# 默认情况下,仓库被创建在容器的/var/lib/registry目录下,建议自行用容器卷映射,方便于宿主机联调 
CONTAINER ID   IMAGE      COMMAND                  CREATED         STATUS         PORTS                                       NAMES
e27d28926331   registry   "/entrypoint.sh /etc…"   4 seconds ago   Up 3 seconds   0.0.0.0:5000->5000/tcp, :::5000->5000/tcp   myregistry
  • 配置私有仓库可信任
$ vim /etc/docker/daemon.json
{ 
  "registry-mirrors": ["https://po13h3y1.mirror.aliyuncs.com","http://hub-mirror.c.163.com","https://mirror.ccs.tencentyun.com","http://f1361db2.m.daocloud.io"],
  "insecure-registries" : ["110.41.20.249:5000"]
}

service docker restart

3.2.9.2 手动创建和服务编排部署LNMP网站平台

  1. 创建overlay网络
docker network create -d overlay lnmp

( MySQL先启动,其次 PHP 启动,最后是 Nginx 启动 )

  1. 创建Nginx服务

Nginx Dockerfile

FROM centos:6

MAINTAINER <zhongzhiwei zhongzhiwei@kubesphere.io>
# 获取最新Yum源信息 & 下载相应软件
RUN curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-vault-6.10.repo && \
yum install -y gcc gcc-c++ make openssh-server pcre-devel openssl zlib-devel

ADD http://nginx.org/download/nginx-1.12.2.tar.gz /tmp
RUN cd /tmp && \
    tar -zxvf nginx-1.12.2.tar.gz && \
    cd nginx-1.12.2 && \
    ./configure --prefix=/usr/local/nginx && \
    make -j 4 && make install

RUN useradd nginx

# nginx.conf 配置文件内容
# user nginx;
# worker_processes auto;
# error_log /var/log/nginx/error.log;
# pid /run/nginx.pid;
# 
# events {
#     worker_connections 1024;
# }
# 
# http {
#     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  logs/access.log  main;
# 
#     sendfile            on;
#     tcp_nopush          on;
#     tcp_nodelay         on;
#     keepalive_timeout   65;
#     types_hash_max_size 4096;
# 
#     include /etc/nginx/conf.d/*.conf;
# 
#     server {
#         listen       80;
#         listen       [::]:80;
#         server_name  localhost;
#         root         html;
# 
#         index index.html index.php;
#         location ~ \.php$ {
#             root html;
# 
#             fastcgi_pass php-cgi:9000;
#             fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
#             include fastcgi_params;
#         }
#     }
# }
COPY nginx.conf /usr/local/nginx/conf

# 声明容器服务端口
EXPOSE 80

# 启动Nginx服务
CMD ["/usr/local/nginx/sbin/nginx", "-g", "daemon off;"]

Nginx 配置文件

user nginx;
worker_processes auto;
error_log logs/error.log info;
pid       logs/nginx.pid;

events {
    worker_connections 1024;
}

http {
    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  logs/access.log  main;

    sendfile            on;
    tcp_nopush          on;
    tcp_nodelay         on;
    keepalive_timeout   65;
    types_hash_max_size 4096;

    # include /etc/nginx/conf.d/*.conf;

    server {
        listen       80;
        listen       [::]:80;
        server_name  localhost;
        root         html;

        index index.html index.php;
        location ~ \.php$ {
            root html;
            fastcgi_pass php:9000;
            fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
            include fastcgi_params;
        }
    }
}
# 推送并构建镜像
$ docker build -t 10.0.0.100:5000/nginx:v1 -f Dockerfile .
$ docker push 10.0.0.100:5000/nginx:v1
$ curl -XGET http://10.0.0.100:5000/v2/_catalog
{"repositories":["nginx"]}

docker service create --name nginx \
--replicas 3 \
--network lnmp \
--publish 8888:80 \
--mount type=volume,source=wwwroot,destination=/usr/local/nginx/html \
10.0.0.100:5000/nginx:v1

# docker service create --name nginx \
# --replicas 3 \
# --network lnmp \
# --publish 8888:80 \
# --mount type=volume,source=wwwroot,destination=/usr/local/nginx/html \
# nginx:1.23.2-alpine
  1. 创建PHP服务

php Dockerfile

FROM centos:6

MAINTAINER <zhongzhiwei zhongzhiwei@kubesphere.io>

# 获取最新Yum源信息 & 下载相应软件
RUN curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-vault-6.10.repo && \
    yum install -y gcc gcc-c++ gd-devel libxml2-devel libcurl-devel libjpeg-devel libpng-devel openssl-devel

ADD http://docs.php.net/distributions/php-5.6.31.tar.gz /tmp/
RUN cd /tmp/php-5.6.31 && \ 
    ./configure --prefix=/usr/local/php \
    --with-config-file-path=/usr/local/php/etc \
    --with-mysql --with-mysqli \
    --with-openssl --with-ziib --with-curl --with-gd \
    --with-jpeg-dir --with-png-dir --with-iconv \
    --enable-fpm --enable-zip --enable-mbstring && \
    make -j 4 && \
    make install && \
    cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf && \
    sed -i "s/127.0.0.1/0.0.0.0/" /usr/local/php/etc/php-fpm.conf && \
    cp ./sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm && \
    chmod +x /etc/init.d/php-fpm

# rm -rf /tmp /php-5.6.31
COPY php.ini /usr/local/php/etc 
CMD /etc/init.d/php-fpm start && tail -F /var/log/messages
# 声明容器服务端口
EXPOSE 9000

php 配置文件[ 设置时区为上海时区 ]

[PHP]

;;;;;;;;;;;;;;;;;;;
; About php.ini   ;
;;;;;;;;;;;;;;;;;;;
; PHP's initialization file, generally called php.ini, is responsible for
; configuring many of the aspects of PHP's behavior.

; PHP attempts to find and load this configuration from a number of locations.
; The following is a summary of its search order:
; 1. SAPI module specific location.
; 2. The PHPRC environment variable. (As of PHP 5.2.0)
; 3. A number of predefined registry keys on Windows (As of PHP 5.2.0)
; 4. Current working directory (except CLI)
; 5. The web server's directory (for SAPI modules), or directory of PHP
; (otherwise in Windows)
; 6. The directory from the --with-config-file-path compile time option, or the
; Windows directory (C:\windows or C:\winnt)
; See the PHP docs for more specific information.
; http://php.net/configuration.file

; The syntax of the file is extremely simple.  Whitespace and lines
; beginning with a semicolon are silently ignored (as you probably guessed).
; Section headers (e.g. [Foo]) are also silently ignored, even though
; they might mean something in the future.

; Directives following the section heading [PATH=/www/mysite] only
; apply to PHP files in the /www/mysite directory.  Directives
; following the section heading [HOST=www.example.com] only apply to
; PHP files served from www.example.com.  Directives set in these
; special sections cannot be overridden by user-defined INI files or
; at runtime. Currently, [PATH=] and [HOST=] sections only work under
; CGI/FastCGI.
; http://php.net/ini.sections

; Directives are specified using the following syntax:
; directive = value
; Directive names are *case sensitive* - foo=bar is different from FOO=bar.
; Directives are variables used to configure PHP or PHP extensions.
; There is no name validation.  If PHP can't find an expected
; directive because it is not set or is mistyped, a default value will be used.

; The value can be a string, a number, a PHP constant (e.g. E_ALL or M_PI), one
; of the INI constants (On, Off, True, False, Yes, No and None) or an expression
; (e.g. E_ALL & ~E_NOTICE), a quoted string ("bar"), or a reference to a
; previously set variable or directive (e.g. ${foo})

; Expressions in the INI file are limited to bitwise operators and parentheses:
; |  bitwise OR
; ^  bitwise XOR
; &  bitwise AND
; ~  bitwise NOT
; !  boolean NOT

; Boolean flags can be turned on using the values 1, On, True or Yes.
; They can be turned off using the values 0, Off, False or No.

; An empty string can be denoted by simply not writing anything after the equal
; sign, or by using the None keyword:

;  foo =         ; sets foo to an empty string
;  foo = None    ; sets foo to an empty string
;  foo = "None"  ; sets foo to the string 'None'

; If you use constants in your value, and these constants belong to a
; dynamically loaded extension (either a PHP extension or a Zend extension),
; you may only use these constants *after* the line that loads the extension.

;;;;;;;;;;;;;;;;;;;
; About this file ;
;;;;;;;;;;;;;;;;;;;
; PHP comes packaged with two INI files. One that is recommended to be used
; in production environments and one that is recommended to be used in
; development environments.

; php.ini-production contains settings which hold security, performance and
; best practices at its core. But please be aware, these settings may break
; compatibility with older or less security conscience applications. We
; recommending using the production ini in production and testing environments.

; php.ini-development is very similar to its production variant, except it is
; much more verbose when it comes to errors. We recommend using the
; development version only in development environments, as errors shown to
; application users can inadvertently leak otherwise secure information.

; This is php.ini-development INI file.

;;;;;;;;;;;;;;;;;;;
; Quick Reference ;
;;;;;;;;;;;;;;;;;;;
; The following are all the settings which are different in either the production
; or development versions of the INIs with respect to PHP's default behavior.
; Please see the actual settings later in the document for more details as to why
; we recommend these changes in PHP's behavior.

; display_errors
;   Default Value: On
;   Development Value: On
;   Production Value: Off

; display_startup_errors
;   Default Value: Off
;   Development Value: On
;   Production Value: Off

; error_reporting
;   Default Value: E_ALL & ~E_NOTICE & ~E_STRICT & ~E_DEPRECATED
;   Development Value: E_ALL
;   Production Value: E_ALL & ~E_DEPRECATED & ~E_STRICT

; html_errors
;   Default Value: On
;   Development Value: On
;   Production value: On

; log_errors
;   Default Value: Off
;   Development Value: On
;   Production Value: On

; max_input_time
;   Default Value: -1 (Unlimited)
;   Development Value: 60 (60 seconds)
;   Production Value: 60 (60 seconds)

; output_buffering
;   Default Value: Off
;   Development Value: 4096
;   Production Value: 4096

; register_argc_argv
;   Default Value: On
;   Development Value: Off
;   Production Value: Off

; request_order
;   Default Value: None
;   Development Value: "GP"
;   Production Value: "GP"

; session.gc_divisor
;   Default Value: 100
;   Development Value: 1000
;   Production Value: 1000

; session.hash_bits_per_character
;   Default Value: 4
;   Development Value: 5
;   Production Value: 5

; short_open_tag
;   Default Value: On
;   Development Value: Off
;   Production Value: Off

; track_errors
;   Default Value: Off
;   Development Value: On
;   Production Value: Off

; url_rewriter.tags
;   Default Value: "a=href,area=href,frame=src,form=,fieldset="
;   Development Value: "a=href,area=href,frame=src,input=src,form=fakeentry"
;   Production Value: "a=href,area=href,frame=src,input=src,form=fakeentry"

; variables_order
;   Default Value: "EGPCS"
;   Development Value: "GPCS"
;   Production Value: "GPCS"

;;;;;;;;;;;;;;;;;;;;
; php.ini Options  ;
;;;;;;;;;;;;;;;;;;;;
; Name for user-defined php.ini (.htaccess) files. Default is ".user.ini"
;user_ini.filename = ".user.ini"

; To disable this feature set this option to empty value
;user_ini.filename =

; TTL for user-defined php.ini files (time-to-live) in seconds. Default is 300 seconds (5 minutes)
;user_ini.cache_ttl = 300

;;;;;;;;;;;;;;;;;;;;
; Language Options ;
;;;;;;;;;;;;;;;;;;;;

; Enable the PHP scripting language engine under Apache.
; http://php.net/engine
engine = On

; This directive determines whether or not PHP will recognize code between
; <? and ?> tags as PHP source which should be processed as such. It is
; generally recommended that <?php and ?> should be used and that this feature
; should be disabled, as enabling it may result in issues when generating XML
; documents, however this remains supported for backward compatibility reasons.
; Note that this directive does not control the <?= shorthand tag, which can be
; used regardless of this directive.
; Default Value: On
; Development Value: Off
; Production Value: Off
; http://php.net/short-open-tag
short_open_tag = Off

; Allow ASP-style <% %> tags.
; http://php.net/asp-tags
asp_tags = Off

; The number of significant digits displayed in floating point numbers.
; http://php.net/precision
precision = 14

; Output buffering is a mechanism for controlling how much output data
; (excluding headers and cookies) PHP should keep internally before pushing that
; data to the client. If your application's output exceeds this setting, PHP
; will send that data in chunks of roughly the size you specify.
; Turning on this setting and managing its maximum buffer size can yield some
; interesting side-effects depending on your application and web server.
; You may be able to send headers and cookies after you've already sent output
; through print or echo. You also may see performance benefits if your server is
; emitting less packets due to buffered output versus PHP streaming the output
; as it gets it. On production servers, 4096 bytes is a good setting for performance
; reasons.
; Note: Output buffering can also be controlled via Output Buffering Control
;   functions.
; Possible Values:
;   On = Enabled and buffer is unlimited. (Use with caution)
;   Off = Disabled
;   Integer = Enables the buffer and sets its maximum size in bytes.
; Note: This directive is hardcoded to Off for the CLI SAPI
; Default Value: Off
; Development Value: 4096
; Production Value: 4096
; http://php.net/output-buffering
output_buffering = 4096

; You can redirect all of the output of your scripts to a function.  For
; example, if you set output_handler to "mb_output_handler", character
; encoding will be transparently converted to the specified encoding.
; Setting any output handler automatically turns on output buffering.
; Note: People who wrote portable scripts should not depend on this ini
;   directive. Instead, explicitly set the output handler using ob_start().
;   Using this ini directive may cause problems unless you know what script
;   is doing.
; Note: You cannot use both "mb_output_handler" with "ob_iconv_handler"
;   and you cannot use both "ob_gzhandler" and "zlib.output_compression".
; Note: output_handler must be empty if this is set 'On' !!!!
;   Instead you must use zlib.output_handler.
; http://php.net/output-handler
;output_handler =

; Transparent output compression using the zlib library
; Valid values for this option are 'off', 'on', or a specific buffer size
; to be used for compression (default is 4KB)
; Note: Resulting chunk size may vary due to nature of compression. PHP
;   outputs chunks that are few hundreds bytes each as a result of
;   compression. If you prefer a larger chunk size for better
;   performance, enable output_buffering in addition.
; Note: You need to use zlib.output_handler instead of the standard
;   output_handler, or otherwise the output will be corrupted.
; http://php.net/zlib.output-compression
zlib.output_compression = Off

; http://php.net/zlib.output-compression-level
;zlib.output_compression_level = -1

; You cannot specify additional output handlers if zlib.output_compression
; is activated here. This setting does the same as output_handler but in
; a different order.
; http://php.net/zlib.output-handler
;zlib.output_handler =

; Implicit flush tells PHP to tell the output layer to flush itself
; automatically after every output block.  This is equivalent to calling the
; PHP function flush() after each and every call to print() or echo() and each
; and every HTML block.  Turning this option on has serious performance
; implications and is generally recommended for debugging purposes only.
; http://php.net/implicit-flush
; Note: This directive is hardcoded to On for the CLI SAPI
implicit_flush = Off

; The unserialize callback function will be called (with the undefined class'
; name as parameter), if the unserializer finds an undefined class
; which should be instantiated. A warning appears if the specified function is
; not defined, or if the function doesn't include/implement the missing class.
; So only set this entry, if you really want to implement such a
; callback-function.
unserialize_callback_func =

; When floats & doubles are serialized store serialize_precision significant
; digits after the floating point. The default value ensures that when floats
; are decoded with unserialize, the data will remain the same.
serialize_precision = 17

; open_basedir, if set, limits all file operations to the defined directory
; and below.  This directive makes most sense if used in a per-directory
; or per-virtualhost web server configuration file.
; http://php.net/open-basedir
;open_basedir =

; This directive allows you to disable certain functions for security reasons.
; It receives a comma-delimited list of function names.
; http://php.net/disable-functions
disable_functions =

; This directive allows you to disable certain classes for security reasons.
; It receives a comma-delimited list of class names.
; http://php.net/disable-classes
disable_classes =

; Colors for Syntax Highlighting mode.  Anything that's acceptable in
; <span style="color: ???????"> would work.
; http://php.net/syntax-highlighting
;highlight.string  = #DD0000
;highlight.comment = #FF9900
;highlight.keyword = #007700
;highlight.default = #0000BB
;highlight.html    = #000000

; If enabled, the request will be allowed to complete even if the user aborts
; the request. Consider enabling it if executing long requests, which may end up
; being interrupted by the user or a browser timing out. PHP's default behavior
; is to disable this feature.
; http://php.net/ignore-user-abort
;ignore_user_abort = On

; Determines the size of the realpath cache to be used by PHP. This value should
; be increased on systems where PHP opens many files to reflect the quantity of
; the file operations performed.
; http://php.net/realpath-cache-size
;realpath_cache_size = 16k

; Duration of time, in seconds for which to cache realpath information for a given
; file or directory. For systems with rarely changing files, consider increasing this
; value.
; http://php.net/realpath-cache-ttl
;realpath_cache_ttl = 120

; Enables or disables the circular reference collector.
; http://php.net/zend.enable-gc
zend.enable_gc = On

; If enabled, scripts may be written in encodings that are incompatible with
; the scanner.  CP936, Big5, CP949 and Shift_JIS are the examples of such
; encodings.  To use this feature, mbstring extension must be enabled.
; Default: Off
;zend.multibyte = Off

; Allows to set the default encoding for the scripts.  This value will be used
; unless "declare(encoding=...)" directive appears at the top of the script.
; Only affects if zend.multibyte is set.
; Default: ""
;zend.script_encoding =

;;;;;;;;;;;;;;;;;
; Miscellaneous ;
;;;;;;;;;;;;;;;;;

; Decides whether PHP may expose the fact that it is installed on the server
; (e.g. by adding its signature to the Web server header).  It is no security
; threat in any way, but it makes it possible to determine whether you use PHP
; on your server or not.
; http://php.net/expose-php
expose_php = On

;;;;;;;;;;;;;;;;;;;
; Resource Limits ;
;;;;;;;;;;;;;;;;;;;

; Maximum execution time of each script, in seconds
; http://php.net/max-execution-time
; Note: This directive is hardcoded to 0 for the CLI SAPI
max_execution_time = 30

; Maximum amount of time each script may spend parsing request data. It's a good
; idea to limit this time on productions servers in order to eliminate unexpectedly
; long running scripts.
; Note: This directive is hardcoded to -1 for the CLI SAPI
; Default Value: -1 (Unlimited)
; Development Value: 60 (60 seconds)
; Production Value: 60 (60 seconds)
; http://php.net/max-input-time
max_input_time = 60

; Maximum input variable nesting level
; http://php.net/max-input-nesting-level
;max_input_nesting_level = 64

; How many GET/POST/COOKIE input variables may be accepted
; max_input_vars = 1000

; Maximum amount of memory a script may consume (128MB)
; http://php.net/memory-limit
memory_limit = 128M

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; Error handling and logging ;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

; This directive informs PHP of which errors, warnings and notices you would like
; it to take action for. The recommended way of setting values for this
; directive is through the use of the error level constants and bitwise
; operators. The error level constants are below here for convenience as well as
; some common settings and their meanings.
; By default, PHP is set to take action on all errors, notices and warnings EXCEPT
; those related to E_NOTICE and E_STRICT, which together cover best practices and
; recommended coding standards in PHP. For performance reasons, this is the
; recommend error reporting setting. Your production server shouldn't be wasting
; resources complaining about best practices and coding standards. That's what
; development servers and development settings are for.
; Note: The php.ini-development file has this setting as E_ALL. This
; means it pretty much reports everything which is exactly what you want during
; development and early testing.
;
; Error Level Constants:
; E_ALL             - All errors and warnings (includes E_STRICT as of PHP 5.4.0)
; E_ERROR           - fatal run-time errors
; E_RECOVERABLE_ERROR  - almost fatal run-time errors
; E_WARNING         - run-time warnings (non-fatal errors)
; E_PARSE           - compile-time parse errors
; E_NOTICE          - run-time notices (these are warnings which often result
;                     from a bug in your code, but it's possible that it was
;                     intentional (e.g., using an uninitialized variable and
;                     relying on the fact it is automatically initialized to an
;                     empty string)
; E_STRICT          - run-time notices, enable to have PHP suggest changes
;                     to your code which will ensure the best interoperability
;                     and forward compatibility of your code
; E_CORE_ERROR      - fatal errors that occur during PHP's initial startup
; E_CORE_WARNING    - warnings (non-fatal errors) that occur during PHP's
;                     initial startup
; E_COMPILE_ERROR   - fatal compile-time errors
; E_COMPILE_WARNING - compile-time warnings (non-fatal errors)
; E_USER_ERROR      - user-generated error message
; E_USER_WARNING    - user-generated warning message
; E_USER_NOTICE     - user-generated notice message
; E_DEPRECATED      - warn about code that will not work in future versions
;                     of PHP
; E_USER_DEPRECATED - user-generated deprecation warnings
;
; Common Values:
;   E_ALL (Show all errors, warnings and notices including coding standards.)
;   E_ALL & ~E_NOTICE  (Show all errors, except for notices)
;   E_ALL & ~E_NOTICE & ~E_STRICT  (Show all errors, except for notices and coding standards warnings.)
;   E_COMPILE_ERROR|E_RECOVERABLE_ERROR|E_ERROR|E_CORE_ERROR  (Show only errors)
; Default Value: E_ALL & ~E_NOTICE & ~E_STRICT & ~E_DEPRECATED
; Development Value: E_ALL
; Production Value: E_ALL & ~E_DEPRECATED & ~E_STRICT
; http://php.net/error-reporting
error_reporting = E_ALL

; This directive controls whether or not and where PHP will output errors,
; notices and warnings too. Error output is very useful during development, but
; it could be very dangerous in production environments. Depending on the code
; which is triggering the error, sensitive information could potentially leak
; out of your application such as database usernames and passwords or worse.
; For production environments, we recommend logging errors rather than
; sending them to STDOUT.
; Possible Values:
;   Off = Do not display any errors
;   stderr = Display errors to STDERR (affects only CGI/CLI binaries!)
;   On or stdout = Display errors to STDOUT
; Default Value: On
; Development Value: On
; Production Value: Off
; http://php.net/display-errors
display_errors = On

; The display of errors which occur during PHP's startup sequence are handled
; separately from display_errors. PHP's default behavior is to suppress those
; errors from clients. Turning the display of startup errors on can be useful in
; debugging configuration problems. We strongly recommend you
; set this to 'off' for production servers.
; Default Value: Off
; Development Value: On
; Production Value: Off
; http://php.net/display-startup-errors
display_startup_errors = On

; Besides displaying errors, PHP can also log errors to locations such as a
; server-specific log, STDERR, or a location specified by the error_log
; directive found below. While errors should not be displayed on productions
; servers they should still be monitored and logging is a great way to do that.
; Default Value: Off
; Development Value: On
; Production Value: On
; http://php.net/log-errors
log_errors = On

; Set maximum length of log_errors. In error_log information about the source is
; added. The default is 1024 and 0 allows to not apply any maximum length at all.
; http://php.net/log-errors-max-len
log_errors_max_len = 1024

; Do not log repeated messages. Repeated errors must occur in same file on same
; line unless ignore_repeated_source is set true.
; http://php.net/ignore-repeated-errors
ignore_repeated_errors = Off

; Ignore source of message when ignoring repeated messages. When this setting
; is On you will not log errors with repeated messages from different files or
; source lines.
; http://php.net/ignore-repeated-source
ignore_repeated_source = Off

; If this parameter is set to Off, then memory leaks will not be shown (on
; stdout or in the log). This has only effect in a debug compile, and if
; error reporting includes E_WARNING in the allowed list
; http://php.net/report-memleaks
report_memleaks = On

; This setting is on by default.
;report_zend_debug = 0

; Store the last error/warning message in $php_errormsg (boolean). Setting this value
; to On can assist in debugging and is appropriate for development servers. It should
; however be disabled on production servers.
; Default Value: Off
; Development Value: On
; Production Value: Off
; http://php.net/track-errors
track_errors = On

; Turn off normal error reporting and emit XML-RPC error XML
; http://php.net/xmlrpc-errors
;xmlrpc_errors = 0

; An XML-RPC faultCode
;xmlrpc_error_number = 0

; When PHP displays or logs an error, it has the capability of formatting the
; error message as HTML for easier reading. This directive controls whether
; the error message is formatted as HTML or not.
; Note: This directive is hardcoded to Off for the CLI SAPI
; Default Value: On
; Development Value: On
; Production value: On
; http://php.net/html-errors
html_errors = On

; If html_errors is set to On *and* docref_root is not empty, then PHP
; produces clickable error messages that direct to a page describing the error
; or function causing the error in detail.
; You can download a copy of the PHP manual from http://php.net/docs
; and change docref_root to the base URL of your local copy including the
; leading '/'. You must also specify the file extension being used including
; the dot. PHP's default behavior is to leave these settings empty, in which
; case no links to documentation are generated.
; Note: Never use this feature for production boxes.
; http://php.net/docref-root
; Examples
;docref_root = "/phpmanual/"

; http://php.net/docref-ext
;docref_ext = .html

; String to output before an error message. PHP's default behavior is to leave
; this setting blank.
; http://php.net/error-prepend-string
; Example:
;error_prepend_string = "<span style='color: #ff0000'>"

; String to output after an error message. PHP's default behavior is to leave
; this setting blank.
; http://php.net/error-append-string
; Example:
;error_append_string = "</span>"

; Log errors to specified file. PHP's default behavior is to leave this value
; empty.
; http://php.net/error-log
; Example:
;error_log = php_errors.log
; Log errors to syslog (Event Log on Windows).
;error_log = syslog

;windows.show_crt_warning
; Default value: 0
; Development value: 0
; Production value: 0

;;;;;;;;;;;;;;;;;
; Data Handling ;
;;;;;;;;;;;;;;;;;

; The separator used in PHP generated URLs to separate arguments.
; PHP's default setting is "&".
; http://php.net/arg-separator.output
; Example:
;arg_separator.output = "&amp;"

; List of separator(s) used by PHP to parse input URLs into variables.
; PHP's default setting is "&".
; NOTE: Every character in this directive is considered as separator!
; http://php.net/arg-separator.input
; Example:
;arg_separator.input = ";&"

; This directive determines which super global arrays are registered when PHP
; starts up. G,P,C,E & S are abbreviations for the following respective super
; globals: GET, POST, COOKIE, ENV and SERVER. There is a performance penalty
; paid for the registration of these arrays and because ENV is not as commonly
; used as the others, ENV is not recommended on productions servers. You
; can still get access to the environment variables through getenv() should you
; need to.
; Default Value: "EGPCS"
; Development Value: "GPCS"
; Production Value: "GPCS";
; http://php.net/variables-order
variables_order = "GPCS"

; This directive determines which super global data (G,P & C) should be
; registered into the super global array REQUEST. If so, it also determines
; the order in which that data is registered. The values for this directive
; are specified in the same manner as the variables_order directive,
; EXCEPT one. Leaving this value empty will cause PHP to use the value set
; in the variables_order directive. It does not mean it will leave the super
; globals array REQUEST empty.
; Default Value: None
; Development Value: "GP"
; Production Value: "GP"
; http://php.net/request-order
request_order = "GP"

; This directive determines whether PHP registers $argv & $argc each time it
; runs. $argv contains an array of all the arguments passed to PHP when a script
; is invoked. $argc contains an integer representing the number of arguments
; that were passed when the script was invoked. These arrays are extremely
; useful when running scripts from the command line. When this directive is
; enabled, registering these variables consumes CPU cycles and memory each time
; a script is executed. For performance reasons, this feature should be disabled
; on production servers.
; Note: This directive is hardcoded to On for the CLI SAPI
; Default Value: On
; Development Value: Off
; Production Value: Off
; http://php.net/register-argc-argv
register_argc_argv = Off

; When enabled, the ENV, REQUEST and SERVER variables are created when they're
; first used (Just In Time) instead of when the script starts. If these
; variables are not used within a script, having this directive on will result
; in a performance gain. The PHP directive register_argc_argv must be disabled
; for this directive to have any affect.
; http://php.net/auto-globals-jit
auto_globals_jit = On

; Whether PHP will read the POST data.
; This option is enabled by default.
; Most likely, you won't want to disable this option globally. It causes $_POST
; and $_FILES to always be empty; the only way you will be able to read the
; POST data will be through the php://input stream wrapper. This can be useful
; to proxy requests or to process the POST data in a memory efficient fashion.
; http://php.net/enable-post-data-reading
;enable_post_data_reading = Off

; Maximum size of POST data that PHP will accept.
; Its value may be 0 to disable the limit. It is ignored if POST data reading
; is disabled through enable_post_data_reading.
; http://php.net/post-max-size
post_max_size = 8M

; Automatically add files before PHP document.
; http://php.net/auto-prepend-file
auto_prepend_file =

; Automatically add files after PHP document.
; http://php.net/auto-append-file
auto_append_file =

; By default, PHP will output a media type using the Content-Type header. To
; disable this, simply set it to be empty.
;
; PHP's built-in default media type is set to text/html.
; http://php.net/default-mimetype
default_mimetype = "text/html"

; PHP's default character set is set to UTF-8.
; http://php.net/default-charset
default_charset = "UTF-8"

; PHP internal character encoding is set to empty.
; If empty, default_charset is used.
; http://php.net/internal-encoding
;internal_encoding =

; PHP input character encoding is set to empty.
; If empty, default_charset is used.
; http://php.net/input-encoding
;input_encoding =

; PHP output character encoding is set to empty.
; If empty, default_charset is used.
; See also output_buffer.
; http://php.net/output-encoding
;output_encoding =

; Always populate the $HTTP_RAW_POST_DATA variable. PHP's default behavior is
; to disable this feature and it will be removed in a future version.
; If post reading is disabled through enable_post_data_reading,
; $HTTP_RAW_POST_DATA is *NOT* populated.
; http://php.net/always-populate-raw-post-data
;always_populate_raw_post_data = -1

;;;;;;;;;;;;;;;;;;;;;;;;;
; Paths and Directories ;
;;;;;;;;;;;;;;;;;;;;;;;;;

; UNIX: "/path1:/path2"
;include_path = ".:/php/includes"
;
; Windows: "\path1;\path2"
;include_path = ".;c:\php\includes"
;
; PHP's default setting for include_path is ".;/path/to/php/pear"
; http://php.net/include-path

; The root of the PHP pages, used only if nonempty.
; if PHP was not compiled with FORCE_REDIRECT, you SHOULD set doc_root
; if you are running php as a CGI under any web server (other than IIS)
; see documentation for security issues.  The alternate is to use the
; cgi.force_redirect configuration below
; http://php.net/doc-root
doc_root =

; The directory under which PHP opens the script using /~username used only
; if nonempty.
; http://php.net/user-dir
user_dir =

; Directory in which the loadable extensions (modules) reside.
; http://php.net/extension-dir
; extension_dir = "./"
; On windows:
; extension_dir = "ext"

; Directory where the temporary files should be placed.
; Defaults to the system default (see sys_get_temp_dir)
; sys_temp_dir = "/tmp"

; Whether or not to enable the dl() function.  The dl() function does NOT work
; properly in multithreaded servers, such as IIS or Zeus, and is automatically
; disabled on them.
; http://php.net/enable-dl
enable_dl = Off

; cgi.force_redirect is necessary to provide security running PHP as a CGI under
; most web servers.  Left undefined, PHP turns this on by default.  You can
; turn it off here AT YOUR OWN RISK
; **You CAN safely turn this off for IIS, in fact, you MUST.**
; http://php.net/cgi.force-redirect
;cgi.force_redirect = 1

; if cgi.nph is enabled it will force cgi to always sent Status: 200 with
; every request. PHP's default behavior is to disable this feature.
;cgi.nph = 1

; if cgi.force_redirect is turned on, and you are not running under Apache or Netscape
; (iPlanet) web servers, you MAY need to set an environment variable name that PHP
; will look for to know it is OK to continue execution.  Setting this variable MAY
; cause security issues, KNOW WHAT YOU ARE DOING FIRST.
; http://php.net/cgi.redirect-status-env
;cgi.redirect_status_env =

; cgi.fix_pathinfo provides *real* PATH_INFO/PATH_TRANSLATED support for CGI.  PHP's
; previous behaviour was to set PATH_TRANSLATED to SCRIPT_FILENAME, and to not grok
; what PATH_INFO is.  For more information on PATH_INFO, see the cgi specs.  Setting
; this to 1 will cause PHP CGI to fix its paths to conform to the spec.  A setting
; of zero causes PHP to behave as before.  Default is 1.  You should fix your scripts
; to use SCRIPT_FILENAME rather than PATH_TRANSLATED.
; http://php.net/cgi.fix-pathinfo
;cgi.fix_pathinfo=1

; if cgi.discard_path is enabled, the PHP CGI binary can safely be placed outside
; of the web tree and people will not be able to circumvent .htaccess security.
; http://php.net/cgi.dicard-path
;cgi.discard_path=1

; FastCGI under IIS (on WINNT based OS) supports the ability to impersonate
; security tokens of the calling client.  This allows IIS to define the
; security context that the request runs under.  mod_fastcgi under Apache
; does not currently support this feature (03/17/2002)
; Set to 1 if running under IIS.  Default is zero.
; http://php.net/fastcgi.impersonate
;fastcgi.impersonate = 1

; Disable logging through FastCGI connection. PHP's default behavior is to enable
; this feature.
;fastcgi.logging = 0

; cgi.rfc2616_headers configuration option tells PHP what type of headers to
; use when sending HTTP response code. If set to 0, PHP sends Status: header that
; is supported by Apache. When this option is set to 1, PHP will send
; RFC2616 compliant header.
; Default is zero.
; http://php.net/cgi.rfc2616-headers
;cgi.rfc2616_headers = 0

; cgi.check_shebang_line controls whether CGI PHP checks for line starting with #!
; (shebang) at the top of the running script. This line might be needed if the
; script support running both as stand-alone script and via PHP CGI<. PHP in CGI
; mode skips this line and ignores its content if this directive is turned on.
; http://php.net/cgi.check-shebang-line
;cgi.check_shebang_line=1

;;;;;;;;;;;;;;;;
; File Uploads ;
;;;;;;;;;;;;;;;;

; Whether to allow HTTP file uploads.
; http://php.net/file-uploads
file_uploads = On

; Temporary directory for HTTP uploaded files (will use system default if not
; specified).
; http://php.net/upload-tmp-dir
;upload_tmp_dir =

; Maximum allowed size for uploaded files.
; http://php.net/upload-max-filesize
upload_max_filesize = 2M

; Maximum number of files that can be uploaded via a single request
max_file_uploads = 20

;;;;;;;;;;;;;;;;;;
; Fopen wrappers ;
;;;;;;;;;;;;;;;;;;

; Whether to allow the treatment of URLs (like http:// or ftp://) as files.
; http://php.net/allow-url-fopen
allow_url_fopen = On

; Whether to allow include/require to open URLs (like http:// or ftp://) as files.
; http://php.net/allow-url-include
allow_url_include = Off

; Define the anonymous ftp password (your email address). PHP's default setting
; for this is empty.
; http://php.net/from
;from="john@doe.com"

; Define the User-Agent string. PHP's default setting for this is empty.
; http://php.net/user-agent
;user_agent="PHP"

; Default timeout for socket based streams (seconds)
; http://php.net/default-socket-timeout
default_socket_timeout = 60

; If your scripts have to deal with files from Macintosh systems,
; or you are running on a Mac and need to deal with files from
; unix or win32 systems, setting this flag will cause PHP to
; automatically detect the EOL character in those files so that
; fgets() and file() will work regardless of the source of the file.
; http://php.net/auto-detect-line-endings
;auto_detect_line_endings = Off

;;;;;;;;;;;;;;;;;;;;;;
; Dynamic Extensions ;
;;;;;;;;;;;;;;;;;;;;;;

; If you wish to have an extension loaded automatically, use the following
; syntax:
;
;   extension=modulename.extension
;
; For example, on Windows:
;
;   extension=msql.dll
;
; ... or under UNIX:
;
;   extension=msql.so
;
; ... or with a path:
;
;   extension=/path/to/extension/msql.so
;
; If you only provide the name of the extension, PHP will look for it in its
; default extension directory.
;
; Windows Extensions
; Note that ODBC support is built in, so no dll is needed for it.
; Note that many DLL files are located in the extensions/ (PHP 4) ext/ (PHP 5)
; extension folders as well as the separate PECL DLL download (PHP 5).
; Be sure to appropriately set the extension_dir directive.
;
;extension=php_bz2.dll
;extension=php_curl.dll
;extension=php_fileinfo.dll
;extension=php_gd2.dll
;extension=php_gettext.dll
;extension=php_gmp.dll
;extension=php_intl.dll
;extension=php_imap.dll
;extension=php_interbase.dll
;extension=php_ldap.dll
;extension=php_mbstring.dll
;extension=php_exif.dll      ; Must be after mbstring as it depends on it
;extension=php_mysql.dll
;extension=php_mysqli.dll
;extension=php_oci8_12c.dll  ; Use with Oracle Database 12c Instant Client
;extension=php_openssl.dll
;extension=php_pdo_firebird.dll
;extension=php_pdo_mysql.dll
;extension=php_pdo_oci.dll
;extension=php_pdo_odbc.dll
;extension=php_pdo_pgsql.dll
;extension=php_pdo_sqlite.dll
;extension=php_pgsql.dll
;extension=php_shmop.dll

; The MIBS data available in the PHP distribution must be installed. 
; See http://www.php.net/manual/en/snmp.installation.php 
;extension=php_snmp.dll

;extension=php_soap.dll
;extension=php_sockets.dll
;extension=php_sqlite3.dll
;extension=php_sybase_ct.dll
;extension=php_tidy.dll
;extension=php_xmlrpc.dll
;extension=php_xsl.dll

;;;;;;;;;;;;;;;;;;;
; Module Settings ;
;;;;;;;;;;;;;;;;;;;

[CLI Server]
; Whether the CLI web server uses ANSI color coding in its terminal output.
cli_server.color = On

[Date]
; Defines the default timezone used by the date functions
; http://php.net/date.timezone
date.timezone = Asia/Shanghai

; http://php.net/date.default-latitude
;date.default_latitude = 31.7667

; http://php.net/date.default-longitude
;date.default_longitude = 35.2333

; http://php.net/date.sunrise-zenith
;date.sunrise_zenith = 90.583333

; http://php.net/date.sunset-zenith
;date.sunset_zenith = 90.583333

[filter]
; http://php.net/filter.default
;filter.default = unsafe_raw

; http://php.net/filter.default-flags
;filter.default_flags =

[iconv]
; Use of this INI entry is deprecated, use global input_encoding instead.
; If empty, default_charset or input_encoding or iconv.input_encoding is used.
; The precedence is: default_charset < intput_encoding < iconv.input_encoding
;iconv.input_encoding =

; Use of this INI entry is deprecated, use global internal_encoding instead.
; If empty, default_charset or internal_encoding or iconv.internal_encoding is used.
; The precedence is: default_charset < internal_encoding < iconv.internal_encoding
;iconv.internal_encoding =

; Use of this INI entry is deprecated, use global output_encoding instead.
; If empty, default_charset or output_encoding or iconv.output_encoding is used.
; The precedence is: default_charset < output_encoding < iconv.output_encoding
; To use an output encoding conversion, iconv's output handler must be set
; otherwise output encoding conversion cannot be performed.
;iconv.output_encoding =

[intl]
;intl.default_locale =
; This directive allows you to produce PHP errors when some error
; happens within intl functions. The value is the level of the error produced.
; Default is 0, which does not produce any errors.
;intl.error_level = E_WARNING
;intl.use_exceptions = 0

[sqlite3]
;sqlite3.extension_dir =

[Pcre]
;PCRE library backtracking limit.
; http://php.net/pcre.backtrack-limit
;pcre.backtrack_limit=100000

;PCRE library recursion limit.
;Please note that if you set this value to a high number you may consume all
;the available process stack and eventually crash PHP (due to reaching the
;stack size limit imposed by the Operating System).
; http://php.net/pcre.recursion-limit
;pcre.recursion_limit=100000

[Pdo]
; Whether to pool ODBC connections. Can be one of "strict", "relaxed" or "off"
; http://php.net/pdo-odbc.connection-pooling
;pdo_odbc.connection_pooling=strict

;pdo_odbc.db2_instance_name

[Pdo_mysql]
; If mysqlnd is used: Number of cache slots for the internal result set cache
; http://php.net/pdo_mysql.cache_size
pdo_mysql.cache_size = 2000

; Default socket name for local MySQL connects.  If empty, uses the built-in
; MySQL defaults.
; http://php.net/pdo_mysql.default-socket
pdo_mysql.default_socket=

[Phar]
; http://php.net/phar.readonly
;phar.readonly = On

; http://php.net/phar.require-hash
;phar.require_hash = On

;phar.cache_list =

[mail function]
; For Win32 only.
; http://php.net/smtp
SMTP = localhost
; http://php.net/smtp-port
smtp_port = 25

; For Win32 only.
; http://php.net/sendmail-from
;sendmail_from = me@example.com

; For Unix only.  You may supply arguments as well (default: "sendmail -t -i").
; http://php.net/sendmail-path
;sendmail_path =

; Force the addition of the specified parameters to be passed as extra parameters
; to the sendmail binary. These parameters will always replace the value of
; the 5th parameter to mail().
;mail.force_extra_parameters =

; Add X-PHP-Originating-Script: that will include uid of the script followed by the filename
mail.add_x_header = On

; The path to a log file that will log all mail() calls. Log entries include
; the full path of the script, line number, To address and headers.
;mail.log =
; Log mail to syslog (Event Log on Windows).
;mail.log = syslog

[SQL]
; http://php.net/sql.safe-mode
sql.safe_mode = Off

[ODBC]
; http://php.net/odbc.default-db
;odbc.default_db    =  Not yet implemented

; http://php.net/odbc.default-user
;odbc.default_user  =  Not yet implemented

; http://php.net/odbc.default-pw
;odbc.default_pw    =  Not yet implemented

; Controls the ODBC cursor model.
; Default: SQL_CURSOR_STATIC (default).
;odbc.default_cursortype

; Allow or prevent persistent links.
; http://php.net/odbc.allow-persistent
odbc.allow_persistent = On

; Check that a connection is still valid before reuse.
; http://php.net/odbc.check-persistent
odbc.check_persistent = On

; Maximum number of persistent links.  -1 means no limit.
; http://php.net/odbc.max-persistent
odbc.max_persistent = -1

; Maximum number of links (persistent + non-persistent).  -1 means no limit.
; http://php.net/odbc.max-links
odbc.max_links = -1

; Handling of LONG fields.  Returns number of bytes to variables.  0 means
; passthru.
; http://php.net/odbc.defaultlrl
odbc.defaultlrl = 4096

; Handling of binary data.  0 means passthru, 1 return as is, 2 convert to char.
; See the documentation on odbc_binmode and odbc_longreadlen for an explanation
; of odbc.defaultlrl and odbc.defaultbinmode
; http://php.net/odbc.defaultbinmode
odbc.defaultbinmode = 1

;birdstep.max_links = -1

[Interbase]
; Allow or prevent persistent links.
ibase.allow_persistent = 1

; Maximum number of persistent links.  -1 means no limit.
ibase.max_persistent = -1

; Maximum number of links (persistent + non-persistent).  -1 means no limit.
ibase.max_links = -1

; Default database name for ibase_connect().
;ibase.default_db =

; Default username for ibase_connect().
;ibase.default_user =

; Default password for ibase_connect().
;ibase.default_password =

; Default charset for ibase_connect().
;ibase.default_charset =

; Default timestamp format.
ibase.timestampformat = "%Y-%m-%d %H:%M:%S"

; Default date format.
ibase.dateformat = "%Y-%m-%d"

; Default time format.
ibase.timeformat = "%H:%M:%S"

[MySQL]
; Allow accessing, from PHP's perspective, local files with LOAD DATA statements
; http://php.net/mysql.allow_local_infile
mysql.allow_local_infile = On

; Allow or prevent persistent links.
; http://php.net/mysql.allow-persistent
mysql.allow_persistent = On

; If mysqlnd is used: Number of cache slots for the internal result set cache
; http://php.net/mysql.cache_size
mysql.cache_size = 2000

; Maximum number of persistent links.  -1 means no limit.
; http://php.net/mysql.max-persistent
mysql.max_persistent = -1

; Maximum number of links (persistent + non-persistent).  -1 means no limit.
; http://php.net/mysql.max-links
mysql.max_links = -1

; Default port number for mysql_connect().  If unset, mysql_connect() will use
; the $MYSQL_TCP_PORT or the mysql-tcp entry in /etc/services or the
; compile-time value defined MYSQL_PORT (in that order).  Win32 will only look
; at MYSQL_PORT.
; http://php.net/mysql.default-port
mysql.default_port =

; Default socket name for local MySQL connects.  If empty, uses the built-in
; MySQL defaults.
; http://php.net/mysql.default-socket
mysql.default_socket =

; Default host for mysql_connect() (doesn't apply in safe mode).
; http://php.net/mysql.default-host
mysql.default_host =

; Default user for mysql_connect() (doesn't apply in safe mode).
; http://php.net/mysql.default-user
mysql.default_user =

; Default password for mysql_connect() (doesn't apply in safe mode).
; Note that this is generally a *bad* idea to store passwords in this file.
; *Any* user with PHP access can run 'echo get_cfg_var("mysql.default_password")
; and reveal this password!  And of course, any users with read access to this
; file will be able to reveal the password as well.
; http://php.net/mysql.default-password
mysql.default_password =

; Maximum time (in seconds) for connect timeout. -1 means no limit
; http://php.net/mysql.connect-timeout
mysql.connect_timeout = 60

; Trace mode. When trace_mode is active (=On), warnings for table/index scans and
; SQL-Errors will be displayed.
; http://php.net/mysql.trace-mode
mysql.trace_mode = Off

[MySQLi]

; Maximum number of persistent links.  -1 means no limit.
; http://php.net/mysqli.max-persistent
mysqli.max_persistent = -1

; Allow accessing, from PHP's perspective, local files with LOAD DATA statements
; http://php.net/mysqli.allow_local_infile
;mysqli.allow_local_infile = On

; Allow or prevent persistent links.
; http://php.net/mysqli.allow-persistent
mysqli.allow_persistent = On

; Maximum number of links.  -1 means no limit.
; http://php.net/mysqli.max-links
mysqli.max_links = -1

; If mysqlnd is used: Number of cache slots for the internal result set cache
; http://php.net/mysqli.cache_size
mysqli.cache_size = 2000

; Default port number for mysqli_connect().  If unset, mysqli_connect() will use
; the $MYSQL_TCP_PORT or the mysql-tcp entry in /etc/services or the
; compile-time value defined MYSQL_PORT (in that order).  Win32 will only look
; at MYSQL_PORT.
; http://php.net/mysqli.default-port
mysqli.default_port = 3306

; Default socket name for local MySQL connects.  If empty, uses the built-in
; MySQL defaults.
; http://php.net/mysqli.default-socket
mysqli.default_socket =

; Default host for mysql_connect() (doesn't apply in safe mode).
; http://php.net/mysqli.default-host
mysqli.default_host =

; Default user for mysql_connect() (doesn't apply in safe mode).
; http://php.net/mysqli.default-user
mysqli.default_user =

; Default password for mysqli_connect() (doesn't apply in safe mode).
; Note that this is generally a *bad* idea to store passwords in this file.
; *Any* user with PHP access can run 'echo get_cfg_var("mysqli.default_pw")
; and reveal this password!  And of course, any users with read access to this
; file will be able to reveal the password as well.
; http://php.net/mysqli.default-pw
mysqli.default_pw =

; Allow or prevent reconnect
mysqli.reconnect = Off

[mysqlnd]
; Enable / Disable collection of general statistics by mysqlnd which can be
; used to tune and monitor MySQL operations.
; http://php.net/mysqlnd.collect_statistics
mysqlnd.collect_statistics = On

; Enable / Disable collection of memory usage statistics by mysqlnd which can be
; used to tune and monitor MySQL operations.
; http://php.net/mysqlnd.collect_memory_statistics
mysqlnd.collect_memory_statistics = On

; Records communication from all extensions using mysqlnd to the specified log
; file.
; http://php.net/mysqlnd.debug
;mysqlnd.debug =

; Defines which queries will be logged.
; http://php.net/mysqlnd.log_mask
;mysqlnd.log_mask = 0

; Default size of the mysqlnd memory pool, which is used by result sets.
; http://php.net/mysqlnd.mempool_default_size
;mysqlnd.mempool_default_size = 16000

; Size of a pre-allocated buffer used when sending commands to MySQL in bytes.
; http://php.net/mysqlnd.net_cmd_buffer_size
;mysqlnd.net_cmd_buffer_size = 2048

; Size of a pre-allocated buffer used for reading data sent by the server in
; bytes.
; http://php.net/mysqlnd.net_read_buffer_size
;mysqlnd.net_read_buffer_size = 32768

; Timeout for network requests in seconds.
; http://php.net/mysqlnd.net_read_timeout
;mysqlnd.net_read_timeout = 31536000

; SHA-256 Authentication Plugin related. File with the MySQL server public RSA
; key.
; http://php.net/mysqlnd.sha256_server_public_key
;mysqlnd.sha256_server_public_key =

[OCI8]

; Connection: Enables privileged connections using external
; credentials (OCI_SYSOPER, OCI_SYSDBA)
; http://php.net/oci8.privileged-connect
;oci8.privileged_connect = Off

; Connection: The maximum number of persistent OCI8 connections per
; process. Using -1 means no limit.
; http://php.net/oci8.max-persistent
;oci8.max_persistent = -1

; Connection: The maximum number of seconds a process is allowed to
; maintain an idle persistent connection. Using -1 means idle
; persistent connections will be maintained forever.
; http://php.net/oci8.persistent-timeout
;oci8.persistent_timeout = -1

; Connection: The number of seconds that must pass before issuing a
; ping during oci_pconnect() to check the connection validity. When
; set to 0, each oci_pconnect() will cause a ping. Using -1 disables
; pings completely.
; http://php.net/oci8.ping-interval
;oci8.ping_interval = 60

; Connection: Set this to a user chosen connection class to be used
; for all pooled server requests with Oracle 11g Database Resident
; Connection Pooling (DRCP).  To use DRCP, this value should be set to
; the same string for all web servers running the same application,
; the database pool must be configured, and the connection string must
; specify to use a pooled server.
;oci8.connection_class =

; High Availability: Using On lets PHP receive Fast Application
; Notification (FAN) events generated when a database node fails. The
; database must also be configured to post FAN events.
;oci8.events = Off

; Tuning: This option enables statement caching, and specifies how
; many statements to cache. Using 0 disables statement caching.
; http://php.net/oci8.statement-cache-size
;oci8.statement_cache_size = 20

; Tuning: Enables statement prefetching and sets the default number of
; rows that will be fetched automatically after statement execution.
; http://php.net/oci8.default-prefetch
;oci8.default_prefetch = 100

; Compatibility. Using On means oci_close() will not close
; oci_connect() and oci_new_connect() connections.
; http://php.net/oci8.old-oci-close-semantics
;oci8.old_oci_close_semantics = Off

[PostgreSQL]
; Allow or prevent persistent links.
; http://php.net/pgsql.allow-persistent
pgsql.allow_persistent = On

; Detect broken persistent links always with pg_pconnect().
; Auto reset feature requires a little overheads.
; http://php.net/pgsql.auto-reset-persistent
pgsql.auto_reset_persistent = Off

; Maximum number of persistent links.  -1 means no limit.
; http://php.net/pgsql.max-persistent
pgsql.max_persistent = -1

; Maximum number of links (persistent+non persistent).  -1 means no limit.
; http://php.net/pgsql.max-links
pgsql.max_links = -1

; Ignore PostgreSQL backends Notice message or not.
; Notice message logging require a little overheads.
; http://php.net/pgsql.ignore-notice
pgsql.ignore_notice = 0

; Log PostgreSQL backends Notice message or not.
; Unless pgsql.ignore_notice=0, module cannot log notice message.
; http://php.net/pgsql.log-notice
pgsql.log_notice = 0

[Sybase-CT]
; Allow or prevent persistent links.
; http://php.net/sybct.allow-persistent
sybct.allow_persistent = On

; Maximum number of persistent links.  -1 means no limit.
; http://php.net/sybct.max-persistent
sybct.max_persistent = -1

; Maximum number of links (persistent + non-persistent).  -1 means no limit.
; http://php.net/sybct.max-links
sybct.max_links = -1

; Minimum server message severity to display.
; http://php.net/sybct.min-server-severity
sybct.min_server_severity = 10

; Minimum client message severity to display.
; http://php.net/sybct.min-client-severity
sybct.min_client_severity = 10

; Set per-context timeout
; http://php.net/sybct.timeout
;sybct.timeout=

;sybct.packet_size

; The maximum time in seconds to wait for a connection attempt to succeed before returning failure.
; Default: one minute
;sybct.login_timeout=

; The name of the host you claim to be connecting from, for display by sp_who.
; Default: none
;sybct.hostname=

; Allows you to define how often deadlocks are to be retried. -1 means "forever".
; Default: 0
;sybct.deadlock_retry_count=

[bcmath]
; Number of decimal digits for all bcmath functions.
; http://php.net/bcmath.scale
bcmath.scale = 0

[browscap]
; http://php.net/browscap
;browscap = extra/browscap.ini

[Session]
; Handler used to store/retrieve data.
; http://php.net/session.save-handler
session.save_handler = files

; Argument passed to save_handler.  In the case of files, this is the path
; where data files are stored. Note: Windows users have to change this
; variable in order to use PHP's session functions.
;
; The path can be defined as:
;
;     session.save_path = "N;/path"
;
; where N is an integer.  Instead of storing all the session files in
; /path, what this will do is use subdirectories N-levels deep, and
; store the session data in those directories.  This is useful if
; your OS has problems with many files in one directory, and is
; a more efficient layout for servers that handle many sessions.
;
; NOTE 1: PHP will not create this directory structure automatically.
;         You can use the script in the ext/session dir for that purpose.
; NOTE 2: See the section on garbage collection below if you choose to
;         use subdirectories for session storage
;
; The file storage module creates files using mode 600 by default.
; You can change that by using
;
;     session.save_path = "N;MODE;/path"
;
; where MODE is the octal representation of the mode. Note that this
; does not overwrite the process's umask.
; http://php.net/session.save-path
;session.save_path = "/tmp"

; Whether to use strict session mode.
; Strict session mode does not accept uninitialized session ID and regenerate
; session ID if browser sends uninitialized session ID. Strict mode protects
; applications from session fixation via session adoption vulnerability. It is
; disabled by default for maximum compatibility, but enabling it is encouraged.
; https://wiki.php.net/rfc/strict_sessions
session.use_strict_mode = 0

; Whether to use cookies.
; http://php.net/session.use-cookies
session.use_cookies = 1

; http://php.net/session.cookie-secure
;session.cookie_secure =

; This option forces PHP to fetch and use a cookie for storing and maintaining
; the session id. We encourage this operation as it's very helpful in combating
; session hijacking when not specifying and managing your own session id. It is
; not the be-all and end-all of session hijacking defense, but it's a good start.
; http://php.net/session.use-only-cookies
session.use_only_cookies = 1

; Name of the session (used as cookie name).
; http://php.net/session.name
session.name = PHPSESSID

; Initialize session on request startup.
; http://php.net/session.auto-start
session.auto_start = 0

; Lifetime in seconds of cookie or, if 0, until browser is restarted.
; http://php.net/session.cookie-lifetime
session.cookie_lifetime = 0

; The path for which the cookie is valid.
; http://php.net/session.cookie-path
session.cookie_path = /

; The domain for which the cookie is valid.
; http://php.net/session.cookie-domain
session.cookie_domain =

; Whether or not to add the httpOnly flag to the cookie, which makes it inaccessible to browser scripting languages such as JavaScript.
; http://php.net/session.cookie-httponly
session.cookie_httponly =

; Handler used to serialize data.  php is the standard serializer of PHP.
; http://php.net/session.serialize-handler
session.serialize_handler = php

; Defines the probability that the 'garbage collection' process is started
; on every session initialization. The probability is calculated by using
; gc_probability/gc_divisor. Where session.gc_probability is the numerator
; and gc_divisor is the denominator in the equation. Setting this value to 1
; when the session.gc_divisor value is 100 will give you approximately a 1% chance
; the gc will run on any give request.
; Default Value: 1
; Development Value: 1
; Production Value: 1
; http://php.net/session.gc-probability
session.gc_probability = 1

; Defines the probability that the 'garbage collection' process is started on every
; session initialization. The probability is calculated by using the following equation:
; gc_probability/gc_divisor. Where session.gc_probability is the numerator and
; session.gc_divisor is the denominator in the equation. Setting this value to 1
; when the session.gc_divisor value is 100 will give you approximately a 1% chance
; the gc will run on any give request. Increasing this value to 1000 will give you
; a 0.1% chance the gc will run on any give request. For high volume production servers,
; this is a more efficient approach.
; Default Value: 100
; Development Value: 1000
; Production Value: 1000
; http://php.net/session.gc-divisor
session.gc_divisor = 1000

; After this number of seconds, stored data will be seen as 'garbage' and
; cleaned up by the garbage collection process.
; http://php.net/session.gc-maxlifetime
session.gc_maxlifetime = 1440

; NOTE: If you are using the subdirectory option for storing session files
;       (see session.save_path above), then garbage collection does *not*
;       happen automatically.  You will need to do your own garbage
;       collection through a shell script, cron entry, or some other method.
;       For example, the following script would is the equivalent of
;       setting session.gc_maxlifetime to 1440 (1440 seconds = 24 minutes):
;          find /path/to/sessions -cmin +24 -type f | xargs rm

; Check HTTP Referer to invalidate externally stored URLs containing ids.
; HTTP_REFERER has to contain this substring for the session to be
; considered as valid.
; http://php.net/session.referer-check
session.referer_check =

; How many bytes to read from the file.
; http://php.net/session.entropy-length
;session.entropy_length = 32

; Specified here to create the session id.
; http://php.net/session.entropy-file
; Defaults to /dev/urandom
; On systems that don't have /dev/urandom but do have /dev/arandom, this will default to /dev/arandom
; If neither are found at compile time, the default is no entropy file.
; On windows, setting the entropy_length setting will activate the
; Windows random source (using the CryptoAPI)
;session.entropy_file = /dev/urandom

; Set to {nocache,private,public,} to determine HTTP caching aspects
; or leave this empty to avoid sending anti-caching headers.
; http://php.net/session.cache-limiter
session.cache_limiter = nocache

; Document expires after n minutes.
; http://php.net/session.cache-expire
session.cache_expire = 180

; trans sid support is disabled by default.
; Use of trans sid may risk your users' security.
; Use this option with caution.
; - User may send URL contains active session ID
;   to other person via. email/irc/etc.
; - URL that contains active session ID may be stored
;   in publicly accessible computer.
; - User may access your site with the same session ID
;   always using URL stored in browser's history or bookmarks.
; http://php.net/session.use-trans-sid
session.use_trans_sid = 0

; Select a hash function for use in generating session ids.
; Possible Values
;   0  (MD5 128 bits)
;   1  (SHA-1 160 bits)
; This option may also be set to the name of any hash function supported by
; the hash extension. A list of available hashes is returned by the hash_algos()
; function.
; http://php.net/session.hash-function
session.hash_function = 0

; Define how many bits are stored in each character when converting
; the binary hash data to something readable.
; Possible values:
;   4  (4 bits: 0-9, a-f)
;   5  (5 bits: 0-9, a-v)
;   6  (6 bits: 0-9, a-z, A-Z, "-", ",")
; Default Value: 4
; Development Value: 5
; Production Value: 5
; http://php.net/session.hash-bits-per-character
session.hash_bits_per_character = 5

; The URL rewriter will look for URLs in a defined set of HTML tags.
; form/fieldset are special; if you include them here, the rewriter will
; add a hidden <input> field with the info which is otherwise appended
; to URLs.  If you want XHTML conformity, remove the form entry.
; Note that all valid entries require a "=", even if no value follows.
; Default Value: "a=href,area=href,frame=src,form=,fieldset="
; Development Value: "a=href,area=href,frame=src,input=src,form=fakeentry"
; Production Value: "a=href,area=href,frame=src,input=src,form=fakeentry"
; http://php.net/url-rewriter.tags
url_rewriter.tags = "a=href,area=href,frame=src,input=src,form=fakeentry"

; Enable upload progress tracking in $_SESSION
; Default Value: On
; Development Value: On
; Production Value: On
; http://php.net/session.upload-progress.enabled
;session.upload_progress.enabled = On

; Cleanup the progress information as soon as all POST data has been read
; (i.e. upload completed).
; Default Value: On
; Development Value: On
; Production Value: On
; http://php.net/session.upload-progress.cleanup
;session.upload_progress.cleanup = On

; A prefix used for the upload progress key in $_SESSION
; Default Value: "upload_progress_"
; Development Value: "upload_progress_"
; Production Value: "upload_progress_"
; http://php.net/session.upload-progress.prefix
;session.upload_progress.prefix = "upload_progress_"

; The index name (concatenated with the prefix) in $_SESSION
; containing the upload progress information
; Default Value: "PHP_SESSION_UPLOAD_PROGRESS"
; Development Value: "PHP_SESSION_UPLOAD_PROGRESS"
; Production Value: "PHP_SESSION_UPLOAD_PROGRESS"
; http://php.net/session.upload-progress.name
;session.upload_progress.name = "PHP_SESSION_UPLOAD_PROGRESS"

; How frequently the upload progress should be updated.
; Given either in percentages (per-file), or in bytes
; Default Value: "1%"
; Development Value: "1%"
; Production Value: "1%"
; http://php.net/session.upload-progress.freq
;session.upload_progress.freq =  "1%"

; The minimum delay between updates, in seconds
; Default Value: 1
; Development Value: 1
; Production Value: 1
; http://php.net/session.upload-progress.min-freq
;session.upload_progress.min_freq = "1"

[MSSQL]
; Allow or prevent persistent links.
mssql.allow_persistent = On

; Maximum number of persistent links.  -1 means no limit.
mssql.max_persistent = -1

; Maximum number of links (persistent+non persistent).  -1 means no limit.
mssql.max_links = -1

; Minimum error severity to display.
mssql.min_error_severity = 10

; Minimum message severity to display.
mssql.min_message_severity = 10

; Compatibility mode with old versions of PHP 3.0.
mssql.compatibility_mode = Off

; Connect timeout
;mssql.connect_timeout = 5

; Query timeout
;mssql.timeout = 60

; Valid range 0 - 2147483647.  Default = 4096.
;mssql.textlimit = 4096

; Valid range 0 - 2147483647.  Default = 4096.
;mssql.textsize = 4096

; Limits the number of records in each batch.  0 = all records in one batch.
;mssql.batchsize = 0

; Specify how datetime and datetim4 columns are returned
; On => Returns data converted to SQL server settings
; Off => Returns values as YYYY-MM-DD hh:mm:ss
;mssql.datetimeconvert = On

; Use NT authentication when connecting to the server
mssql.secure_connection = Off

; Specify max number of processes. -1 = library default
; msdlib defaults to 25
; FreeTDS defaults to 4096
;mssql.max_procs = -1

; Specify client character set.
; If empty or not set the client charset from freetds.conf is used
; This is only used when compiled with FreeTDS
;mssql.charset = "ISO-8859-1"

[Assertion]
; Assert(expr); active by default.
; http://php.net/assert.active
;assert.active = On

; Issue a PHP warning for each failed assertion.
; http://php.net/assert.warning
;assert.warning = On

; Don't bail out by default.
; http://php.net/assert.bail
;assert.bail = Off

; User-function to be called if an assertion fails.
; http://php.net/assert.callback
;assert.callback = 0

; Eval the expression with current error_reporting().  Set to true if you want
; error_reporting(0) around the eval().
; http://php.net/assert.quiet-eval
;assert.quiet_eval = 0

[COM]
; path to a file containing GUIDs, IIDs or filenames of files with TypeLibs
; http://php.net/com.typelib-file
;com.typelib_file =

; allow Distributed-COM calls
; http://php.net/com.allow-dcom
;com.allow_dcom = true

; autoregister constants of a components typlib on com_load()
; http://php.net/com.autoregister-typelib
;com.autoregister_typelib = true

; register constants casesensitive
; http://php.net/com.autoregister-casesensitive
;com.autoregister_casesensitive = false

; show warnings on duplicate constant registrations
; http://php.net/com.autoregister-verbose
;com.autoregister_verbose = true

; The default character set code-page to use when passing strings to and from COM objects.
; Default: system ANSI code page
;com.code_page=

[mbstring]
; language for internal character representation.
; This affects mb_send_mail() and mbstrig.detect_order.
; http://php.net/mbstring.language
;mbstring.language = Japanese

; Use of this INI entry is deprecated, use global internal_encoding instead.
; internal/script encoding.
; Some encoding cannot work as internal encoding. (e.g. SJIS, BIG5, ISO-2022-*)
; If empty, default_charset or internal_encoding or iconv.internal_encoding is used.
; The precedence is: default_charset < internal_encoding < iconv.internal_encoding
;mbstring.internal_encoding =

; Use of this INI entry is deprecated, use global input_encoding instead.
; http input encoding.
; mbstring.encoding_traslation = On is needed to use this setting.
; If empty, default_charset or input_encoding or mbstring.input is used.
; The precedence is: default_charset < intput_encoding < mbsting.http_input
; http://php.net/mbstring.http-input
;mbstring.http_input =

; Use of this INI entry is deprecated, use global output_encoding instead.
; http output encoding.
; mb_output_handler must be registered as output buffer to function.
; If empty, default_charset or output_encoding or mbstring.http_output is used.
; The precedence is: default_charset < output_encoding < mbstring.http_output
; To use an output encoding conversion, mbstring's output handler must be set
; otherwise output encoding conversion cannot be performed.
; http://php.net/mbstring.http-output
;mbstring.http_output =

; enable automatic encoding translation according to
; mbstring.internal_encoding setting. Input chars are
; converted to internal encoding by setting this to On.
; Note: Do _not_ use automatic encoding translation for
;       portable libs/applications.
; http://php.net/mbstring.encoding-translation
;mbstring.encoding_translation = Off

; automatic encoding detection order.
; "auto" detect order is changed according to mbstring.language
; http://php.net/mbstring.detect-order
;mbstring.detect_order = auto

; substitute_character used when character cannot be converted
; one from another
; http://php.net/mbstring.substitute-character
;mbstring.substitute_character = none

; overload(replace) single byte functions by mbstring functions.
; mail(), ereg(), etc are overloaded by mb_send_mail(), mb_ereg(),
; etc. Possible values are 0,1,2,4 or combination of them.
; For example, 7 for overload everything.
; 0: No overload
; 1: Overload mail() function
; 2: Overload str*() functions
; 4: Overload ereg*() functions
; http://php.net/mbstring.func-overload
;mbstring.func_overload = 0

; enable strict encoding detection.
; Default: Off
;mbstring.strict_detection = On

; This directive specifies the regex pattern of content types for which mb_output_handler()
; is activated.
; Default: mbstring.http_output_conv_mimetype=^(text/|application/xhtml\+xml)
;mbstring.http_output_conv_mimetype=

[gd]
; Tell the jpeg decode to ignore warnings and try to create
; a gd image. The warning will then be displayed as notices
; disabled by default
; http://php.net/gd.jpeg-ignore-warning
;gd.jpeg_ignore_warning = 0

[exif]
; Exif UNICODE user comments are handled as UCS-2BE/UCS-2LE and JIS as JIS.
; With mbstring support this will automatically be converted into the encoding
; given by corresponding encode setting. When empty mbstring.internal_encoding
; is used. For the decode settings you can distinguish between motorola and
; intel byte order. A decode setting cannot be empty.
; http://php.net/exif.encode-unicode
;exif.encode_unicode = ISO-8859-15

; http://php.net/exif.decode-unicode-motorola
;exif.decode_unicode_motorola = UCS-2BE

; http://php.net/exif.decode-unicode-intel
;exif.decode_unicode_intel    = UCS-2LE

; http://php.net/exif.encode-jis
;exif.encode_jis =

; http://php.net/exif.decode-jis-motorola
;exif.decode_jis_motorola = JIS

; http://php.net/exif.decode-jis-intel
;exif.decode_jis_intel    = JIS

[Tidy]
; The path to a default tidy configuration file to use when using tidy
; http://php.net/tidy.default-config
;tidy.default_config = /usr/local/lib/php/default.tcfg

; Should tidy clean and repair output automatically?
; WARNING: Do not use this option if you are generating non-html content
; such as dynamic images
; http://php.net/tidy.clean-output
tidy.clean_output = Off

[soap]
; Enables or disables WSDL caching feature.
; http://php.net/soap.wsdl-cache-enabled
soap.wsdl_cache_enabled=1

; Sets the directory name where SOAP extension will put cache files.
; http://php.net/soap.wsdl-cache-dir
soap.wsdl_cache_dir="/tmp"

; (time to live) Sets the number of second while cached file will be used
; instead of original one.
; http://php.net/soap.wsdl-cache-ttl
soap.wsdl_cache_ttl=86400

; Sets the size of the cache limit. (Max. number of WSDL files to cache)
soap.wsdl_cache_limit = 5

[sysvshm]
; A default size of the shared memory segment
;sysvshm.init_mem = 10000

[ldap]
; Sets the maximum number of open links or -1 for unlimited.
ldap.max_links = -1

[mcrypt]
; For more information about mcrypt settings see http://php.net/mcrypt-module-open

; Directory where to load mcrypt algorithms
; Default: Compiled in into libmcrypt (usually /usr/local/lib/libmcrypt)
;mcrypt.algorithms_dir=

; Directory where to load mcrypt modes
; Default: Compiled in into libmcrypt (usually /usr/local/lib/libmcrypt)
;mcrypt.modes_dir=

[dba]
;dba.default_handler=

[opcache]
; Determines if Zend OPCache is enabled
;opcache.enable=0

; Determines if Zend OPCache is enabled for the CLI version of PHP
;opcache.enable_cli=0

; The OPcache shared memory storage size.
;opcache.memory_consumption=64

; The amount of memory for interned strings in Mbytes.
;opcache.interned_strings_buffer=4

; The maximum number of keys (scripts) in the OPcache hash table.
; Only numbers between 200 and 100000 are allowed.
;opcache.max_accelerated_files=2000

; The maximum percentage of "wasted" memory until a restart is scheduled.
;opcache.max_wasted_percentage=5

; When this directive is enabled, the OPcache appends the current working
; directory to the script key, thus eliminating possible collisions between
; files with the same name (basename). Disabling the directive improves
; performance, but may break existing applications.
;opcache.use_cwd=1

; When disabled, you must reset the OPcache manually or restart the
; webserver for changes to the filesystem to take effect.
;opcache.validate_timestamps=1

; How often (in seconds) to check file timestamps for changes to the shared
; memory storage allocation. ("1" means validate once per second, but only
; once per request. "0" means always validate)
;opcache.revalidate_freq=2

; Enables or disables file search in include_path optimization
;opcache.revalidate_path=0

; If disabled, all PHPDoc comments are dropped from the code to reduce the
; size of the optimized code.
;opcache.save_comments=1

; If disabled, PHPDoc comments are not loaded from SHM, so "Doc Comments"
; may be always stored (save_comments=1), but not loaded by applications
; that don't need them anyway.
;opcache.load_comments=1

; If enabled, a fast shutdown sequence is used for the accelerated code
;opcache.fast_shutdown=0

; Allow file existence override (file_exists, etc.) performance feature.
;opcache.enable_file_override=0

; A bitmask, where each bit enables or disables the appropriate OPcache
; passes
;opcache.optimization_level=0xffffffff

;opcache.inherited_hack=1
;opcache.dups_fix=0

; The location of the OPcache blacklist file (wildcards allowed).
; Each OPcache blacklist file is a text file that holds the names of files
; that should not be accelerated. The file format is to add each filename
; to a new line. The filename may be a full path or just a file prefix
; (i.e., /var/www/x  blacklists all the files and directories in /var/www
; that start with 'x'). Line starting with a ; are ignored (comments).
;opcache.blacklist_filename=

; Allows exclusion of large files from being cached. By default all files
; are cached.
;opcache.max_file_size=0

; Check the cache checksum each N requests.
; The default value of "0" means that the checks are disabled.
;opcache.consistency_checks=0

; How long to wait (in seconds) for a scheduled restart to begin if the cache
; is not being accessed.
;opcache.force_restart_timeout=180

; OPcache error_log file name. Empty string assumes "stderr".
;opcache.error_log=

; All OPcache errors go to the Web server log.
; By default, only fatal errors (level 0) or errors (level 1) are logged.
; You can also enable warnings (level 2), info messages (level 3) or
; debug messages (level 4).
;opcache.log_verbosity_level=1

; Preferred Shared Memory back-end. Leave empty and let the system decide.
;opcache.preferred_memory_model=

; Protect the shared memory from unexpected writing during script execution.
; Useful for internal debugging only.
;opcache.protect_memory=0

; Validate cached file permissions.
; opcache.validate_permission=0

; Prevent name collisions in chroot'ed environment.
; opcache.validate_root=0

[curl]
; A default value for the CURLOPT_CAINFO option. This is required to be an
; absolute path.
;curl.cainfo =

[openssl]
; The location of a Certificate Authority (CA) file on the local filesystem
; to use when verifying the identity of SSL/TLS peers. Most users should
; not specify a value for this directive as PHP will attempt to use the
; OS-managed cert stores in its absence. If specified, this value may still
; be overridden on a per-stream basis via the "cafile" SSL stream context
; option.
;openssl.cafile=

; If openssl.cafile is not specified or if the CA file is not found, the
; directory pointed to by openssl.capath is searched for a suitable
; certificate. This value must be a correctly hashed certificate directory.
; Most users should not specify a value for this directive as PHP will
; attempt to use the OS-managed cert stores in its absence. If specified,
; this value may still be overridden on a per-stream basis via the "capath"
; SSL stream context option.
;openssl.capath=

; Local Variables:
; tab-width: 4
; End:
$ docker build -t 10.0.0.100:5000/php:v1 -f Dockerfile .
$ docker push 10.0.0.100:5000/php:v1
$ curl -XGET http://10.0.0.100:5000/v2/_catalog
{"repositories":["nginx","php"]}

docker service create \
--name php \
--replicas 3 \
--network lnmp \
--mount type=volume,source=wwwroot,destination=/usr/local/nginx/html \
10.0.0.100:5000/php:v1
  1. 创建MySQL 服务

MySQL 配置文件

$ mkdir mysql/conf && cd mysql/conf && vim my.cnf
[mysqld]
user = mysql
port = 3306
datadir = /var/lib/mysql
socket  = /var/lib/mysql/mysql.sock
pid-file  = /var/run/mysql/mysql.pid
log_error = /var/log/mysql/error.log
character-set-server = utf8mb4
character-set-client = utf8mb4
max_connections = 3600

$ docker config create my.cnf my.cnf
docker service create --name mysql \
--replicas 1 \
--network lnmp \
--config src=my.cnf,target="/etc/mysql/conf.d/my.cnf" \
--mount type=volume,source=dbdata,destination=/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
-e MYSQL_USER=wordpress \
-e MYSQL_PASSWORD=wp123456 \
-e MYSQL_DATABASE=wordpress \
mysql:5.6
  1. 检查 Docker Service 的服务状态
$ docker service ls 
ID             NAME      MODE         REPLICAS   IMAGE                      PORTS
k7zuik6ypgoe   mysql     replicated   1/1        mysql:5.6                  
r6uxwxcgx7vm   nginx     replicated   3/3        10.0.0.100:5000/nginx:v1   *:8888->80/tcp
jncd9dgbvbe9   php       replicated   3/3        10.0.0.100:5000/php:v1     

$ docker node ls 
ID                            HOSTNAME         STATUS    AVAILABILITY   MANAGER STATUS   ENGINE VERSION
ah1qkwni3gm1ifh5g20e9890i *   swarm-master     Ready     Active         Reachable        20.10.21
r3rcx30cg5nhdhnt1c1ucw579     swarm-worker01   Ready     Active         Leader           20.10.21
rciafdim7e47siyfew1zbezv6     swarm-worker02   Ready     Active         Reachable        20.10.21

$ docker volume ls 
DRIVER    VOLUME NAME
local     wwwroot

$ docker volume inspect wwwroot 
[
    {
        "CreatedAt": "2022-11-27T10:25:09Z",
        "Driver": "local",
        "Labels": null,
        "Mountpoint": "/var/lib/docker/volumes/wwwroot/_data",
        "Name": "wwwroot",
        "Options": null,
        "Scope": "local"
    }
]

$ curl 10.0.0.100:8888
<!DOCTYPE html>
<html>
<head>
<title>Welcome to nginx!</title>
<style>
    body {
        width: 35em;
        margin: 0 auto;
        font-family: Tahoma, Verdana, Arial, sans-serif;
    }
</style>
</head>
<body>
<h1>Welcome to nginx!</h1>
<p>If you see this page, the nginx web server is successfully installed and
working. Further configuration is required.</p>

<p>For online documentation and support please refer to
<a href="http://nginx.org/">nginx.org</a>.<br/>
Commercial support is available at
<a href="http://nginx.com/">nginx.com</a>.</p>

<p><em>Thank you for using nginx.</em></p>
</body>
</html>

# 可以将 wordpress 的目录解压到/var/lib/docker/volumes/wwwroot/_data
http://:8888/wordpress 后续的操作就是 WordPress 根据引导进行部署即可

01 Docker 进阶 %26 Kubernetes 入门 - 图38

01 Docker 进阶 %26 Kubernetes 入门 - 图39

01 Docker 进阶 %26 Kubernetes 入门 - 图40

这样 博客就搭建完成了!

3.2.10 服务编排之集群部署 LNMP 网站平台

Stack 能够在单个声明文件中定义复杂的多服务应用,还提供了简单的方式来部署应用并管理其完整的生命周期:初始化部署 -> 健康检查 -> 扩容 -> 更新 -> 回滚,以及其他功能!可以简单地理解为Stack是集群下的Compose。 Docker在进行多服务部署和管理时通常会使用Docker Stack来解决大规模部署管理问题,Docker引擎在1.12 版本集成了Docker Swarm, 内置新的容器编排工具docker stack,通过提供期望状态、滚动升级、简单易用、扩缩容、健康检查等特性简化了应用的管理。 从体系结构上来讲,Stack 位于 Docker 应用层级的最顶端。Stack 基于服务进行构建,而服务又基于容器,如下图所示。

01 Docker 进阶 %26 Kubernetes 入门 - 图41

命令 描述
docker stack deploy 部署新stack或更新现有stack
docker stack ls 显示stack列表
docker stack ps 列出stack中的任务
docker stack rm 移除一个或多个stack
docker stack services 列出stack中的服务

01 Docker 进阶 %26 Kubernetes 入门 - 图42

范例:service_stack.yml 文件内容

version: "3.3"
services:
  nginx:
    image: 10.0.0.100:5000/nginx:v1
    ports:
    - 10780:80
    networks:
    - lnmp_net
    volumes:
    - type: volume
      source: wwwroot
      target: /usr/local/nginx/html
    deploy:
      mode: replicated
      replicas: 3
    depends_on:
    - php
    - mysql

  php:
    image: 10.0.0.100:5000/php:v1
    networks:
    - lnmp_net
    volumes:
    - type: volume
      source: wwwroot
      target: /usr/local/nginx/html
    deploy:
      mode: replicated
      replicas: 3

  mysql:
    image: mysql:5.6
    ports:
    - 3306:3306
    networks:
    - lnmp_net
    volumes:
    - "dbdata:/var/lib/mysql"
    command: --character-set-server=utf8
    environment:
      MYSQL_ROOT_PASSWORD: 123456
      MYSQL_PASSWORD: wordpress
      MYSQL_USER: wordpress
      MYSQL_DATABASE: wp123456

networks:
  lnmp_net:
    driver: overlay

volumes:
  wwwroot:
  dbdata:
# 一键部署: 
$ docker stack deploy -c service_stack.yml lnmp
# 查看Stack的信息:
$ docker stack ls 
NAME      SERVICES   ORCHESTRATOR
lnmp      3          Swarm
$ docker stack ps lnmp 
ID             NAME           IMAGE                      NODE             DESIRED STATE   CURRENT STATE           ERROR     PORTS
mglgdqq4va13   lnmp_mysql.1   mysql:5.6                  swarm-master     Running         Running 3 minutes ago             
09a2z81ne9pq   lnmp_nginx.1   10.0.0.100:5000/nginx:v1   swarm-worker02   Running         Running 3 minutes ago             
4mv0xi4sa789   lnmp_nginx.2   10.0.0.100:5000/nginx:v1   swarm-worker01   Running         Running 3 minutes ago             
iteqedxlnhgt   lnmp_nginx.3   10.0.0.100:5000/nginx:v1   swarm-master     Running         Running 3 minutes ago             
49ehbzo7wmw1   lnmp_php.1     10.0.0.100:5000/php:v1     swarm-worker01   Running         Running 4 minutes ago             
ovwql5x794g9   lnmp_php.2     10.0.0.100:5000/php:v1     swarm-master     Running         Running 4 minutes ago             
vl2emro7c1ob   lnmp_php.3     10.0.0.100:5000/php:v1     swarm-worker02   Running         Running 4 minutes ago  

# 查看数据卷的情况
$ docker volume ls 
DRIVER    VOLUME NAME
local     lnmp_dbdata
local     lnmp_wwwroot

# Docker Stack底层就是使用Service进行创建
$ docker service ls 
ID             NAME         MODE         REPLICAS   IMAGE                      PORTS
0y5q4s0gjezm   lnmp_mysql   replicated   1/1        mysql:5.6                  *:3306->3306/tcp
lhpwag24nmep   lnmp_nginx   replicated   3/3        10.0.0.100:5000/nginx:v1   *:10780->80/tcp
oe4sglwc7287   lnmp_php     replicated   3/3        10.0.0.100:5000/php:v1     

$ curl 10.0.0.100:10780
<!DOCTYPE html>
<html>
<head>
<title>Welcome to nginx!</title>
<style>
    body {
        width: 35em;
        margin: 0 auto;
        font-family: Tahoma, Verdana, Arial, sans-serif;
    }
</style>
</head>
<body>
<h1>Welcome to nginx!</h1>
<p>If you see this page, the nginx web server is successfully installed and
working. Further configuration is required.</p>

<p>For online documentation and support please refer to
<a href="http://nginx.org/">nginx.org</a>.<br/>
Commercial support is available at
<a href="http://nginx.com/">nginx.com</a>.</p>

<p><em>Thank you for using nginx.</em></p>
</body>
</html>

:::color1 生产环境中数据持久化一定要使用共享存储的解决方案!

:::

3.3 Kubernetes

Go 是 Google 开发的一种编译型、并发型,并具有垃圾回收功能的编程语言。 Go 的表现力强、简洁、干净、高效。它的并发机制使它能够轻松地编写程序,从而最大限度地利用多核和网络机器,而它新颖的类型系统则使灵活的模块化程序构造成为可能。Go 快速编译成机器代码,但又具有垃圾回收的便利性和运行时反射的强大功能。它是一种快速的、静态类型化的、编译后的语言,感觉就像一种动态类型化的、解释的语言。 Go 语言是基于 Inferno 操作系统所开发的。Go 语言于 2009 年 11 月正式宣布推出,成为开放源代码项目,并在 Linux 及 Mac OS X 平台上进行了实现,后追加 Windows 系统下的实现。 Go(又称Golang)是Google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的编程语言,被称为云计算时代的C语言。

Go 语言!必须掌握!

需要跳转到:kubernetes(k8s)从入门到精通

kubernetes(k8s)从入门到精通