一、Nginx介绍

  1. Nginx (engine x) 是一个高性能的HTTP和反向代理服务,也是一个IMAP/POP3/SMTP服务。
  2.  
  3. Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点(俄文:Рамблер)开发的,第一个公开版本0.1.0发布于2004104日。
  1. Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行。
  2.  
  3. 其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好,
  4.  
  5. 中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。

Nginx是一款由俄罗斯的程序设计师所开发高性能的Web和反向代理服务器,也是一个IMAP/POP3/SMTP代理服务器

轻量级的web服务器

延伸版本tengine(淘宝)、openresrt(章亦春)等

http://nginx.org官网

http://www.nginx.cn/doc/index.html中文文档

Nginx管理

Nginx优化

Nginx负载均衡

声明

Nginx安装

官网源码包--必须从官网下载

  1. 配置:
  2. 1)检查环境 是否 满足安装条件 依赖解决
  3. 2)指定安装方式 配置文件 命令文件 各种文件放哪里 开启模块功能[内置模块 三方模块]
  4. 3)指定软件安装在哪里

视频是在在虚拟机上进行项目部署

下载并放在/usr/src目录下:

wget http://nginx.org/download/nginx-1.15.5.tar.gz -P /usr/src

  1. cd /usr/src
    解压 tar xf nginx-1.15.5.tar.gz
  1. cd nginx-1.15.5
  2. 安装依赖包:yum -y install gcc pcre-devel zlib zlib -devel
  3.  
  4. 把所有软件安装到直到目录下:./configure --prefix=/usr/local/nginx
    把源码进行编译生成可执行程序:make
    安装:make install
  5. 启动nginx:
  6. 1 cd /usr/local/nginx/
    2 /usr/local/nginx/sbin/nginx
    查看端口是否被占用:
    1lsof -i:80
    2netstat -ntpl

虚拟机安装流程

-------

  1. 安装模块的命令:yum -y install lsof

验证Nginx是否启动:

1、服务器公网地址访问:

2、文本

先安装 sudo yum -y install elinks 才能执行

elinks http://120.79.2.67 --dump

-------

nginx配置文件详解

变量文件

  1. #启动子进程程序默认用户
  2. #user nobody;
  3. #一个主进程和多个工作进程。工作进程是单进程的,且不需要特殊授权即可运行;这里定义的是工作进程数量
  4. worker_processes 1;
  5.  
  6. #全局错误日志的位置及日志格式
  7. #error_log logs/error.log;
  8. #error_log logs/error.log notice;
  9. #error_log logs/error.log info;
  10.  
  11. #pid logs/nginx.pid;
  12.  
  13. events {
  14. #每个工作进程最大的并发数
  15. worker_connections 1024;
  16. }
  17.  
  18. #http服务器设置
  19. http {
  20. #设定mime类型,类型由mime.type文件定义
  21. include mime.types;
  22.  
  23. #
  24. default_type application/octet-stream;
  25.  
  26. #日志格式
  27. #log_format main '$remote_addr - $remote_user [$time_local] "$request" '
  28. # '$status $body_bytes_sent "$http_referer" '
  29. # '"$http_user_agent" "$http_x_forwarded_for"';
  30. #$remote_addr与$http_x_forwarded_for用以记录客户端的ip地址;
  31. #$remote_user:用来记录客户端用户名称;
  32. #$time_local: 用来记录访问时间与时区;
  33. #$request: 用来记录请求的url与http协议;
  34. #$status: 用来记录请求状态;成功是200,
  35. #$body_bytes_sent :记录发送给客户端文件主体内容大小;
  36. #$http_referer:用来记录从那个页面链接访问过来的;
  37. #$http_user_agent:记录客户浏览器的相关信息;
  38.  
  39. #全局访问日志路径
  40. #access_log logs/access.log main;
  41. #sendfile指令指定 nginx 是否调用sendfile 函数(zero copy 方式)来输出文件,对于普通应用,必须设为on。如果用来进行下载等应用磁盘IO重负载应用,可设置为off,以平衡磁盘与网络IO处理速度,降低系统uptime。
  42. sendfile on;
  43.  
  44. #此选项允许或禁止使用socke的TCP_CORK的选项,此选项仅在使用sendfile的时候使用
  45. #tcp_nopush on;
  46.  
  47. #长连接超时时间
  48. #keepalive_timeout 0;
  49. keepalive_timeout 65;
  50.  
  51. #开启压缩
  52. #gzip on;
  53.  
  54. #配置虚拟主机
  55. server {
  56. #虚拟主机使用的端口
  57. listen 80;
  58. #虚拟主机域名
  59. server_name localhost;
  60.  
  61. #虚拟主机支持的字符集
  62. #charset koi8-r;
  63.  
  64. #虚拟主机的访问日志路径
  65. #access_log logs/host.access.log main;
  66.  
  67. #定义web根路径
  68. location / {
  69. #根目录路径
  70. root html;
  71. #索引页
  72. index index.html index.htm;
  73. }
  74.  
  75. #error_page 404 /404.html;
  76.  
  77. # redirect server error pages to the static page /50x.html
  78. #
  79.  
  80. #根据错误码 返回对应的页面
  81. error_page 500 502 503 504 /50x.html;
  82.  
  83. #定义页面路径
  84. location = /50x.html {
  85. root html;
  86. }
  87.  
  88. #定义反向代理服务器 数据服务器是lamp模型
  89. # proxy the PHP scripts to Apache listening on 127.0.0.1:80
  90. #
  91. #location ~ \.php$ {
  92. # proxy_pass http://127.0.0.1;
  93. #}
  94.  
  95. #定义PHP为本机服务的模型
  96. # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
  97. #
  98. #location ~ \.php$ {
  99. # root html;
  100. # fastcgi_pass 127.0.0.1:9000;
  101. # fastcgi_index index.php;
  102. # fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
  103. # include fastcgi_params;
  104. #}
  105.  
  106. # deny access to .htaccess files, if Apache's document root
  107. # concurs with nginx's one
  108. #
  109. #拒绝apache DR目录及子目录下的.htaccess文件访问
  110. #location ~ /\.ht {
  111. # deny all;
  112. #}
  113. }
  114.  
  115. # another virtual host using mix of IP-, name-, and port-based configuration
  116. #
  117. #server {
  118. # listen 8000;
  119. # listen somename:8080;
  120. # server_name somename alias another.alias;
  121.  
  122. # location / {
  123. # root html;
  124. # index index.html index.htm;
  125. # }
  126. #}
  127.  
  128. #https的配置方案
  129. # HTTPS server
  130. #
  131. #server {
  132. # listen 443 ssl;
  133. # server_name localhost;
  134.  
  135. # ssl_certificate cert.pem;
  136. # ssl_certificate_key cert.key;
  137.  
  138. # ssl_session_cache shared:SSL:1m;
  139. # ssl_session_timeout 5m;
  140.  
  141. # ssl_ciphers HIGH:!aNULL:!MD5;
  142. # ssl_prefer_server_ciphers on;
  143.  
  144. # location / {
  145. # root html;
  146. # index index.html index.htm;
  147. # }
  148. #}
  149.  
  150. }

nginx配置文件

查看配置文件命令:

vim ./conf/nginx.conf

  1. 进入配置文件
  1. cd /usr/local/nginx/
  1. cd ./conf
    先敲一些就可以进行编译
    在配置文件下查看进程数:
    cat /proc/cpuinfo |grep "flags"|wc -l

再末尾输入:q重新回到命令行

Nginx默认网址

Nginx虚拟主机

虚拟主机的介绍:

  1. 一个web服务器器软件默认情况下只能发布一个web, 因为一个web分享出去需要三个条件(IPPort(端口)、Domain name(域名))
  2. 一个web服务器器软件如何发布多个web呢?
  3.  
  4. 虚拟主机:就是把⼀一台物理理服务器器划分成多个“虚拟”的服务器器,每一个虚拟主机都可以有独立的域名和独立的目录

目的是让一个web服务器发布多个网站

基于IP的虚拟主机

  1. server {
  2. listen 192.168.10.42:80;
  3. location / {
  4. root html/abc;
  5. index index.html index.htm index.php;
  6. }
  7. }
  8. server {
  9. listen 192.168.10.52:80;
  10. location / {
  11. root html/cbd;
  12. index index.html index.htm;
  13. }
  14. }

基于端口的

  1. server {
  2. listen 80;
  3. #server_name www.abc.com;
  4. location / {
  5. root html/abc;
  6. index index.html index.htm index.php;
  7. }
  8. }
  9. server {
  10. listen 8080;
  11. #server_name www.abc.com;
  12. location / {
  13. root html/cbd;
  14. index index.html index.htm;
  15. }
  16. }

同一个ip下的不同端口

基于域名的

  1. server {
  2. listen 80;
  3. server_name www.abc.com;
  4. location / {
  5. root html/abc;
  6. index index.html index.htm index.php;
  7. }
  8. }
  9. server {
  10. listen 80;
  11. server_name www.cbd.com;
  12. location / {
  13. root html/cbd;
  14. index index.html index.htm;
  15. }
  16. }

小微企业 ------买网站空间

不用买服务器就可以托管网站

Ngnix的反向代理

反向代理介绍:

  1. 代理服务器,客户机在发送请求时,不会直接发送给目的主机,而是先发送给代理服务器,代理服务接受客户机请求之后,
    再向主机发出,并接收目的主机返回的数据,存放在代理理服务器器的硬盘中,再发送给客户机。

买车人   4s店   厂家

  1. 堡垒机场景
  1. 内网服务器器发布场景
  1. 缓存场景

反向代理原理

  1. 1) 客户端通过浏览器器 发起请求 代理理服务器器
  2. 2)代理理服务器器 接受请求
  3. 3) 代理理服务器器 发起请求 业务服务器器
  4. 4)业务服务器器 接受请求
  5. 5)业务服务器器 处理理请求
  6. 6) 业务服务器器 响应请求 代理理服务器器
  7. 7)代理理服务器器 响应请求 客户端
  8. 8)客户端通过浏览器器渲染请求并展示给⽤用户

反向代理实现

  1. location / {
  2. index index.php index.html index.htm; #定义⾸首⻚页索引⽂文件的名称
  3. proxy_pass http://mysvr ;#请求转向mysvr 定义的服务器器列列表
  4. proxy_set_header Host $host;
  5. proxy_set_header X-Real-IP $remote_addr;
  6. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  7. client_max_body_size 10m; #允许客户端请求的最⼤大单⽂文件字节数
  8. client_body_buffer_size 128k; #缓冲区代理理缓冲⽤用户端请求的最⼤大字节数,
  9. proxy_connect_timeout 90; #nginx跟后端服务器器连接超时时间(代理理连接超时)
  10. proxy_send_timeout 90; #后端服务器器数据回传时间(代理理发送超时)
  11. proxy_read_timeout 90; #连接成功后,后端服务器器响应时间(代理理接收超时)
  12. proxy_buffer_size 4k; #设置代理理服务器器(nginx)保存⽤用户头信息的缓冲区⼤大⼩小
  13. proxy_buffers 4 32k; #proxy_buffers缓冲区,⽹网⻚页平均在32k以下的话,这样设置
  14. proxy_busy_buffers_size 64k; #⾼高负荷下缓冲⼤大⼩小(proxy_buffers*2)
  15. proxy_temp_file_write_size 64k; #设定缓存⽂文件夹⼤大⼩小,⼤大于这个值,将从upstream服务器器传
  16. }

Nginx限速

限速介绍:

  1. 限速该特性可以限制某个用户在⼀一个给定时间段内能够产生的HTTP请求数。请求可以简单到就是⼀一个对于主⻚页的GET请求或者一个登陆表格的POST请求。
  2. 限速也可以用于安全目的上,⽐比如暴暴⼒力力密码破解攻击。通过限制进来的请求速率,并且(结合日志)标记出目标URLs来帮助防范DDoS攻击。
    一般地说,限流是用在
  3. 保护上游应⽤用服务器器不不被在同⼀一时刻的⼤大量量⽤用户请求湮没。

应用场景

  1. DDOS防御
  2. 下载场景保护IO

限速原理

  1. 算法思想是:
  2. 水(请求)从上方倒入水桶,从水桶下方流出(被处理理);
  3. 来不不及流出的水存在水桶中(缓冲),以固定速率流出;
  4. 水桶满后水溢出(丢弃)。
  5. 这个算法的核心是:缓存请求、匀速处理、多余的请求直接丢弃。

实现方式

  1. Nginx官方版本限制IP的连接和并发分别有两个模块:
  2. limit_req_zone 用来限制单位时间内的请求数,即速率限制。
  3. limit_req_conn 用来限制同一时间连接数,即并发限制。

模式使用方法

  1. limit_req_zone 参数配置
  2. Syntax: limit_req zone=name [burst=number] [nodelay];
  3. Default:
  4. Context: http, server, location

Nginx URL重写

  1. rewrite模块(ngx_http_rewrite_module
  2. Rewrite功功能是Nginx服务器器提供的⼀一个重要功能。几乎是所有的web产品必备技能,⽤用于实现URL重写。URL重写是非常有用的功能,比如它可以在
  3. 我们在改变⽹网站结构后,不不需要客户端修改原来的书签,也不不需要其他⽹网站修改对我们⽹网站的友情链接,还可以在一定程度上提高网站的安全性,能够
  4. 让我们的网站显得更更专业。

  5. Nginx服务器器Rewrite功能的实现是依赖于PCREPerl Compatible Regular ExpressionPerl兼容的正则表达式)的支持,所以在编译安装Nginx之前,
  6. 需要安装PCRE库。

应用场景

  1. 域名变更更 (京东)
  2. 用户跳转 (从某个连接跳到另⼀一个连接)
  3. 伪静态场景 (便便于CDN缓存动态页面数据)

实现:

  1. 1) set   设置变量量
  2. 2) if    负责语句句中的判断
  3. 3) return  返回返回值或URL
  4. 4) break   终止后续的rewrite规则
  5. 5) rewrite  重定向URL
  1. set指令 ⾃自定义变量量
  2. Syntax:
  3. set $variable value;
  4. Default:

  5. Context:
  6. server, location, if
  7. http://www.ayitula.com 重写为 http://www.ayitula.com/baism
  8. location / {
  9. set $name baism;
  10. rewrite ^(.*)$ http://www.ayitula.com/$name;
  11. }

Nginx优化

  1. 标准情况下,软件默认的参数都是对安装软件的硬件标准来设置的,⽬目前我们服务器器的硬件资源远远⼤大于要求的标准,
    所以为了了让服务器器性能更更加出众,充分利利⽤用服
  2. 务器器的硬件资源,我们一般需要优化APP的并发数来提升服务器器的性能。

Nginx集群

传统web访问模型

单点故障解决方案

  1. 1) 部署一台备份服务器器,宕机直接切换
  2. 2) 部署多台服务器器,根据DNS的轮询解析机制去实现⽤用户分发
  3. 问题:
  4. 1方案:服务器器利利⽤用率低,成本⾼高,切换不不及时,服务器器压力力依然⼤大
  5. 2方案: 优势是用户处理理速度得到了了提升,但是当其中一台故障,就会有一部分用户访问不不了了⽹网站

集群概念

  1. 将多个物理理机器器组成一个逻辑计算机,实现负载均衡和容错
  2. 计算机集群简称集群,是一种计算机系统, 它通过一组松散集成的计算机软件或硬件连接起来⾼高度紧密地协作完成计算
  3. 工作。在某种意义上,他们可以被看作是一台计算机。 (百度解释)
  4.  
  5. 组成要素
  6. 1VIP:
  7. 一个IP地址
  8. 2)分发器器:
  9. nginx
  10. 3)数据服务器器:
  11. Web服务器器

部署一个基于python语言的web发布环境

  1. 1 一门面向对象的语言
  2. 2)拥有丰富的库
  3. 3)可移植性
  4. 4)免费、开源
  5. 5)简单易易学
  6. 可做软件开发、人工智能、web开发等等

部署流程:

  1. Cnetos7.5+Nginx+python+Django+uwsgi+mysql
  2. 实验部署流程
  3. 1)安装Nginx
  4. 2)安装python
  5. 3)安装mysql
  6. 4)部署发布平台
  7. 5)测试

1、前面已经安装了Nginx

2、mysql_install(中小型公司)

  1. ⼀一个关系型数据库,由瑞典的AB公司开发,后来卖给了了oracle公司,⽬目前分为商业版和社区版
  2. ⽬目前有量量⼤大版本 mysql5 mysql8
  3. ⽬目前建议⼤大家先使⽤用5.7最新版本即可。官⽅方提供了了RPM和源码两种格式
  1. 1)安装依赖包
  2. 2) 升级cmake⼯工具
  3. 3) 升级boost库⽂文件
  4. 4) 安装mysql
  5. 5) 启动测试
  1. mysql_install
  2. ⼀一、前期准备
  3. 依赖包
  4. 1cmake命令 2.8以上
  5. https://cmake.org/download/
  6. boost Boost库是⼀一个可移植、提供源代码的C++库,作为标准库的后备,是C++标准化进
  7. 程的开发引擎之⼀一
  8. https://www.boost.org/
  9. mysql
  10. https://dev.mysql.com/downloads/mysql/5.7.html#downloads
  11. ⼆二、install
  12. yum -y install ncurses-devel gcc-* bzip2-*
  13. 1)cmake install
  14. tar xf cmake-3.6.0-rc1.tar
  15. cd cmake-3.6.0-rc1
  16. ./configure
  17. make
  18. make install
  19. 2boost
  20. tar xf boost_1_59_0.tar.bz2
  21. mv boost_1_59_0 /usr/local/boost
  22. 3)mysql
  23. useradd -s /sbin/nologin -r mysql
  24. mkdir -pv /usr/local/mysql/data
  25. tar xf mysql...tar.xx
  26. cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/
  27. usr/local/mysql/data/ -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock
  28. -DDOWNLOAD_BOOST=0 -DWITH_INNODBBASE_STORAGE_ENGINE=1 -
  29. DENABLE_LOCAL_INFILE=1 -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8 -
  30. DDEFAULT_COLLATION=utf8_general_ci -DMYSQL_USER=mysql -DWITH_DEBUG=0
  31. -DWITH_EMBEDED_SERVER=0 -DDOWNLOAD_BOOST=1 -DWITH_BOOST=/usr/local/
  32. boost
  33. ##解释
  34. -DCMAKE_INSTALL_PREFIX 指定安装路路径
  35. -DMYSQL_DATADIR 指定存放数据⽂文件的⽬目录位置
  36. -DMYSQL_UNIX_ADDR 指定mysql.sock的路路径
  37. -DDOWNLOAD_BOOST=0 不不下载boost库⽂文件
  38. -DWITH_INNODBBASE_STORAGE_ENGINE=1 指定默认存储引擎
  39. -DENABLE_LOCAL_INFILE=1 允许客户端使⽤用local data
  40. local 导⼊入本地数据⽂文件
  41. -DEXTRA_CHARSETS=all ⽀支持所有字符集
  42. -DDEFAULT_CHARSET=utf8 默认字符集是UTF-8
  43. -DDEFAULT_COLLATION=utf8_general_ci 数据库校对规则
  44. -DMYSQL_USER=mysql 管理理⽤用户是mysql
  45. -DWITH_DEBUG=0 关闭debug
  46. -DWITH_EMBEDED_SERVER=0 ⽣生成⼀一个libmysqld.a(.so)的
  47. 库,这个库同时集成了了mysql服务与客户端API
  48. -DWITH_BOOST=/usr/local/boost 指定boost的路路径
  49. make
  50. make install
  51. 4)安装后操作
  52. cp support-files/mysql.server /etc/init.d/mysql
  53. chmod 755 /etc/init.d/mysql
  54. chown mysql.mysql /usr/local/mysql/ -R
  55. ln -sf /usr/local/mysql/bin/* /usr/bin/
  56. ln -sf /usr/local/mysql/lib/* /usr/lib/
  57. ln -sf /usr/local/mysql/libexec/* /usr/local/libexec
  58. ln -sf /usr/local/mysql/share/man/man1/* /usr/share/man/man1
  59. ln -sf /usr/local/mysql/share/man/man8/* /usr/share/man/man8
  60. /usr/local/mysql/bin/mysqld --initialize --user=mysql --basedir=/
  61. usr/local/mysql/ --datadir=/usr/local/mysql/data/
  62. 修改配置⽂文件 确保路路径正确
  63. [root@web01 ~]# egrep -v "^#|^$" /etc/my.cnf
  64. [mysqld]
  65. datadir=/usr/local/mysql/data
  66. socket=/usr/local/mysql/mysql.sock
  67. symbolic-links=0
  68. [mysqld_safe]
  69. log-error=/var/log/mysql.log
  70. pid-file=/var/run/mysql.pid
  71. !includedir /etc/my.cnf.d
  72. 5)启动mysql
  73. 初始化 root@localhost: /q%Zpaoio5i1
  74. 6)密码修改

先安装依赖

企业应用--Nginx&web部署的更多相关文章

  1. nginx上部署python web

    nginx上部署python web http://uwsgi-docs.readthedocs.io/en/latest/tutorials/Django_and_nginx.html

  2. 基于flask+gunicorn+nginx来部署web App

    基于flask+gunicorn&&nginx来部署web App WSGI协议 Web框架致力于如何生成HTML代码,而Web服务器用于处理和响应HTTP请求.Web框架和Web服务 ...

  3. 用nginx的反向代理机制解决前端跨域问题在nginx上部署web静态页面

    用nginx的反向代理机制解决前端跨域问题在nginx上部署web静态页面 1.什么是跨域以及产生原因 跨域是指a页面想获取b页面资源,如果a.b页面的协议.域名.端口.子域名不同,或是a页面为ip地 ...

  4. linux篇之Nginx web服务器简单部署

    一.安装部署nginx 1. 部署前先对nginx介绍下别嫌BB: 如果你听说或使用过Apache软件,那么很快就会熟悉Nginx软件,与Apache软件类似, Nginx(“engine x”)是一 ...

  5. Nginx如何部署静态web项目

    环境准备 windows nginx web项目资源包 准备资源包 这里拿layuimini项目举例,从码云上克隆下来直接访问提示需要部署在web服务器当中才能正常浏览演示 准备Nginx 进入解压后 ...

  6. nginx服务部署 说明

    第1章 常用的软件 1.1 常用来提供静态服务的软件   Apache :这是中小型Web服务的主流,Web服务器中的老大哥,   Nginx :大型网站Web服务的主流,曾经Web服务器中的初生牛犊 ...

  7. nginx web服务器应用

    Nginx介绍 Nginx是一个开源的,支持高性能,高并发的www服务和代理服务软件,因具有高并发(特别是静态资源),占用系统资源少等特性,且功能丰富而逐渐流行起来.功能应用上,Nginx不但是一个优 ...

  8. Linux实战教学笔记38:企业级Nginx Web服务优化实战(下)

    四,Nginx站点目录及文件URL访问控制 4.1 根据扩展名限制程序和文件访问 Web2.0时代,绝大多数网站都是以用户为中心多的,例如:bbs,blog,sns产品,这几个产品都有一个共同特点,就 ...

  9. Nginx服务部署

    1 企业常用网站服务 处理静态资源:nginx.apache.Lighttpd处理动态资源:tomcat(java语言编写).php(php语言编写).python(python语言编写)nginx网 ...

随机推荐

  1. 廖雪峰Java2面向对象编程-2数据封装-1方法重载

    方法重载 方法重载Overload是指:多个方法的方法名相同,但各自的参数不同 参数的个数不同 参数的类型不同 参数位置不同 方法返回值类型通常都是相同的 目的:相同功能的方法使用同一名字,便于调用 ...

  2. C语言强化——字符串(1)

    实现 mystrcpy(), mystrcmp(), mystrcat(), mystrlen() ; #include<stdio.h> void mystrcpy(char *i,ch ...

  3. Django简介及Django项目的创建详述

    Django简介 Django是一个开源的Web应用框架,由Python写成.但是,百度百科中讲它采用了MVC框架模式,其实这个解释不准确. 确切的讲,Django的模式是:路由控制+MTV模式.所谓 ...

  4. [UE4]RetainerBox,控制UI更新频率,把渲染后的UI当成Texture

    RetainerBox是一个容器,只会影响其容器内的UI,RetainerBox的作用: 一.控制UI更新频率(可能是为有优化性能) 1.在UserWidget中添加Retainer Box容器,并在 ...

  5. [UE4]打包EXE

    Building configuration 1.Development:开发模式.不会压缩文件 2.Shipping,成品模式.移动版本会自动压缩文件

  6. mysql为什么要分库分表?

    1 基本思想之什么是分库分表?从字面上简单理解,就是把原本存储于一个库的数据分块存储到多个库上,把原本存储于一个表的数据分块存储到多个表上. 2 基本思想之为什么要分库分表? 单表操作数据量有最优值, ...

  7. MySQL 8.0的关系数据库新特性详解

    前言 MySQL 8.0 当前的最新版本是 8.0.4 rc,估计正式版本出来也快了.本文介绍几个 8.0 在关系数据库方面的主要新特性. 你可能已经知道 MySQL 从版本 5.7 开始提供了 No ...

  8. SAS 数值转日期

    DATA _NULL_;FORMAT A YYMMDDN8.;B=PUT(20180101,$8.);A=INPUT(B,YYMMDD8.);PUT B= A=;RUN; 输出:47   DATA _ ...

  9. sas transpose 代码备忘

    OPTIONS NOCENTER LS=MAX PS=MAX; LIBNAME S '.\report';/*PROC PRINT DATA=S.doquestionr(WHERE=(sid=1972 ...

  10. SQL按分隔符拆分字段串

    CREATE VIEW [dbo].[Split_BusinessUnit] AS WITH tt AS ( SELECT BusinessUnit.BusinessUnitId , Business ...