Nginx + Django + fastcgi 서버 환경 구축

10475 단어 django서버nginx
내 설치 배경: 클 라 이언 트: win 7 서버: VM 설치 centos 6.4 다음은 튜 토리 얼:
1. 관련 소스 프로그램 가 져 오기:
sudo -s
LANG=C
yum -y install gcc gcc-c++ autoconf libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel ncurses ncurses-devel curl curl-devel e2fsprogs e2fsprogs-devel krb5 krb5-devel libidn libidn-devel openssl openssl-devel openldap openldap-devel nss_ldap openldap-clients openldap-servers

2. 소스 코드 nginx 다운로드:
mkdir -p /data0/software
cd /data0/software
wget http://sysoev.ru/nginx/nginx-0.8.46.tar.gz
wget http://blog.s135.com/soft/linux/nginx_php/pcre/pcre-8.10.tar.gz

3. ww 사용자 와 그룹 만 들 기:
/usr/sbin/groupadd www
/usr/sbin/useradd -g www www
mkdir -p /data0/htdocs/blog
chmod +w /data0/htdocs/blog
chown -R www:www /data0/htdocs/blog
mkdir -p /data0/htdocs/www
chmod +w /data0/htdocs/www
chown -R www:www /data0/htdocs/www

4. Nginx 0.8.46 설치:
1. Nginx 설치 에 필요 한 pcre 라 이브 러 리:
tar zxvf pcre-8.10.tar.gz
cd pcre-8.10/
./configure
make && make install
cd ../

2. Nginx 설치
tar zxvf nginx-0.8.46.tar.gz
cd nginx-0.8.46/
./configure --user=www --group=www --prefix=/usr/local/webserver/nginx --with-http_stub_status_module --with-http_ssl_module
make && make install
cd ../

3. Nginx 로그 디 렉 터 리 만 들 기
mkdir -p /data1/logs
chmod +w /data1/logs
chown -R www:www /data1/logs

4. Nginx 프로필 만 들 기
①, / usr / local / webserver / nginx / conf / 디 렉 터 리 에 nginx. conf 파일 생 성:
rm -f /usr/local/webserver/nginx/conf/nginx.conf
vi /usr/local/webserver/nginx/conf/nginx.conf

다음 내용 을 입력 하 십시오:
user  www www;

worker_processes 8;

error_log  /data1/logs/nginx_error.log  crit;

pid        /usr/local/webserver/nginx/nginx.pid;

#Specifies the value for maximum file descriptors that can be opened by this process. 
worker_rlimit_nofile 65535;

events 
{
  use epoll;
  worker_connections 65535;
}

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

  #charset  gb2312;
      
  server_names_hash_bucket_size 128;
  client_header_buffer_size 32k;
  large_client_header_buffers 4 32k;
  client_max_body_size 8m;
      
  sendfile on;
  tcp_nopush     on;

  keepalive_timeout 60;

  tcp_nodelay on;

  fastcgi_connect_timeout 300;
  fastcgi_send_timeout 300;
  fastcgi_read_timeout 300;
  fastcgi_buffer_size 64k;
  fastcgi_buffers 4 64k;
  fastcgi_busy_buffers_size 128k;
  fastcgi_temp_file_write_size 128k;

  gzip on;
  gzip_min_length  1k;
  gzip_buffers     4 16k;
  gzip_http_version 1.0;
  gzip_comp_level 2;
  gzip_types       text/plain application/x-javascript text/css application/xml;
  gzip_vary on;

  #limit_zone  crawler  $binary_remote_addr  10m;
}

5. Nginx 시작
ulimit -SHn 65535
/usr/local/webserver/nginx/sbin/nginx

5. 자동 시작 설정 Nginx
vi /etc/rc.local

말미 에 다음 과 같은 내용 을 추가 합 니 다.
ulimit -SHn 65535
/usr/local/webserver/nginx/sbin/nginx

6. 리 눅 스 커 널 파라미터 최적화
4. 567913. 말미 에 다음 과 같은 내용 을 추가 합 니 다.
vi /etc/sysctl.conf

설정 즉시 적용:
# Add
net.ipv4.tcp_max_syn_backlog = 65536
net.core.netdev_max_backlog =  32768
net.core.somaxconn = 32768


net.core.wmem_default = 8388608
net.core.rmem_default = 8388608
net.core.rmem_max = 16777216
net.core.wmem_max = 16777216


net.ipv4.tcp_timestamps = 0
net.ipv4.tcp_synack_retries = 2
net.ipv4.tcp_syn_retries = 2


net.ipv4.tcp_tw_recycle = 1
#net.ipv4.tcp_tw_len = 1
net.ipv4.tcp_tw_reuse = 1


net.ipv4.tcp_mem = 94500000 915000000 927000000
net.ipv4.tcp_max_orphans = 3276800


#net.ipv4.tcp_fin_timeout = 30
#net.ipv4.tcp_keepalive_time = 120
net.ipv4.ip_local_port_range = 1024  65535

7. Nginx 서 비 스 를 멈 추 지 않 고 Nginx 설정 수정 / usr / local / webserver / nginx / conf / nginx. conf 설정 파일 을 부 드 럽 게 변경 한 후 다음 명령 을 실행 하여 설정 파일 이 올 바른 지 확인 하 십시오.
/sbin/sysctl -p

화면 에 다음 두 줄 의 정 보 를 표시 하면 설정 파일 이 정확 하 다 는 것 을 설명 합 니 다.
  the configuration file /usr/local/webserver/nginx/conf/nginx.conf syntax is ok
  the configuration file /usr/local/webserver/nginx/conf/nginx.conf was tested successfully
8. 매일 정시 에 Nginx 로 그 를 자 르 는 스 크 립 트 작성
1. 스 크 립 트 / usr / local / webserver / nginx / sbin / cut 생 성nginx_log.sh
/usr/local/webserver/nginx/sbin/nginx -t

다음 내용 을 입력 하 십시오:
vi /usr/local/webserver/nginx/sbin/cut_nginx_log.sh

2. crontab 설정, 매일 새벽 00: 00 nginx 접근 로그 절단
#!/bin/bash
# This script run at 00:00


# The Nginx logs path
logs_path="/usr/local/webserver/nginx/logs/"


mkdir -p ${logs_path}$(date -d "yesterday" +"%Y")/$(date -d "yesterday" +"%m")/
mv ${logs_path}access.log ${logs_path}$(date -d "yesterday" +"%Y")/$(date -d "yesterday" +"%m")/access_$(date -d "yesterday" +"%Y%m%d").log
kill -USR1 `cat /usr/local/webserver/nginx/nginx.pid`

다음 내용 을 입력 하 십시오:
crontab -e

9. Django 다운로드 및 설치
1, 홈 페이지 다운로드 Django
00 00 * * * /bin/bash  /usr/local/webserver/nginx/sbin/cut_nginx_log.sh

2. 스트레스 해소, 설치
wget www.djangoproject.com/download/1.3/tarball/

10. Django 프로젝트 를 Nginx 에 추가 합 니 다. 도 메 인 이름 으로 접근 하기 위해 서 는 Django 와 nginx 를 결합 해 야 합 니 다. 그러면 nginx. conf 에 server 를 추가 하고 nginx. conf 에 가입 해 야 합 니 다.
tar xzvf Django-1.3.tar.gz
cd Django-1.3
sudo python setup.py install
cd ../
 
nginx / conf / 새로 만 들 기: diango. conf, 다음 코드 를 추가 합 니 다:
# django project
include django.conf;

이상 fstcgi 를 사 용 했 습 니 다.django. conf, 그래서 nginx / conf 에서 새로 만 들 기: fastcgidjango. conf, 다음 내용 을 추가 합 니 다:
# Django project
server {
listen  80;
server_name 192.168.1.128;
#include conf/bots.conf;
location / {
#fastcgi_pass unix:/home/projectname/server.sock;
fastcgi_pass 127.0.0.1:8080;
#include conf/bots.conf;
include   fastcgi_django.conf;
access_log  /data1/logs/nginx_django.log;
}
location ^~ /admin/ {
#fastcgi_pass unix:/home/projectname/server.sock;
include  conf/fastcgi_django.conf;
access_log   off;
#auth_basic “Welcome to admin”;
#auth_basic_user_file /etc/nginx_passwd;
}
location ~* ^.+\.(mpg|avi|mp3|swf|zip|tgz|gz|rar|bz2|doc|xls|exe|ppt|txt|tar|mid|midi|wav|rtf|mpeg)$ {
root   /data0/htdocs/pylabs/media;
limit_rate 2000K;
access_log  /data1/logs/nginx_django_media.log;
access_log   off;
}
location ~* ^.+\.(jpg|jpeg|gif|png|ico|css|bmp|js)$ {
root   /data0/htdocs/pylabs/static;
access_log   off;
expires      30d;
}
location /403.html {
root   /usr/local/webserver/nginx/sbin/nginx;
access_log   off;
}
location /401.html {
root   /usr/local/webserver/nginx/sbin/nginx;
access_log   off;
}
location /404.html {
root   /usr/local/webserver/nginx/sbin/nginx;
access_log   off;
}
location = /_.gif {
empty_gif;
access_log   off;
}
}# Django project
server {
listen  80;
server_name 192.168.1.128;
#include conf/bots.conf;
location / {
#fastcgi_pass unix:/home/projectname/server.sock;
fastcgi_pass 127.0.0.1:8080;
#include conf/bots.conf;
include   fastcgi_django.conf;
access_log  /data1/logs/nginx_django.log;
}
location ^~ /admin/ {
#fastcgi_pass unix:/home/projectname/server.sock;
include  conf/fastcgi_django.conf;
access_log   off;
#auth_basic “Welcome to admin”;
#auth_basic_user_file /etc/nginx_passwd;
}
location ~* ^.+\.(mpg|avi|mp3|swf|zip|tgz|gz|rar|bz2|doc|xls|exe|ppt|txt|tar|mid|midi|wav|rtf|mpeg)$ {
root   /data0/htdocs/pylabs/media;
limit_rate 2000K;
access_log  /data1/logs/nginx_django_media.log;
access_log   off;
}
location ~* ^.+\.(jpg|jpeg|gif|png|ico|css|bmp|js)$ {
root   /data0/htdocs/pylabs/static;
access_log   off;
expires      30d;
}
location /403.html {
root   /usr/local/webserver/nginx/sbin/nginx;
access_log   off;
}
location /401.html {
root   /usr/local/webserver/nginx/sbin/nginx;
access_log   off;
}
location /404.html {
root   /usr/local/webserver/nginx/sbin/nginx;
access_log   off;
}
location = /_.gif {
empty_gif;
access_log   off;
}
}

11. flup 설치
fastcgi_pass_header Authorization;
fastcgi_intercept_errors off;
fastcgi_param PATH_INFO         $fastcgi_script_name;
fastcgi_param REQUEST_METHOD      $request_method;
fastcgi_param QUERY_STRING        $query_string;
fastcgi_param CONTENT_TYPE        $content_type;
fastcgi_param CONTENT_LENGTH      $content_length;
fastcgi_param SERVER_PORT         $server_port;
fastcgi_param SERVER_PROTOCOL     $server_protocol;
fastcgi_param SERVER_NAME         $server_name;
fastcgi_param REQUEST_URI         $request_uri;
fastcgi_param DOCUMENT_URI      $document_uri;
fastcgi_param DOCUMENT_ROOT          $document_root;
fastcgi_param SERVER_ADDR            $server_addr;
fastcgi_param REMOTE_USER         $remote_user;
fastcgi_param REMOTE_ADDR         $remote_addr;
fastcgi_param REMOTE_PORT         $remote_port;
fastcgi_param SERVER_SOFTWARE     "nginx";
fastcgi_param GATEWAY_INTERFACE     "CGI/1.1";
#fastcgi_param GEO            $geo;
fastcgi_param UID_SET         $uid_set;
fastcgi_param UID_GOT         $uid_got;
#fastcgi_param SCRIPT_NAME        $fastcgi_script_name;

성공 알림:
Installed /usr/lib/python2.4/site-packages/setuptools-0.6c9-py2.4.egg
Processing dependencies for setuptools==0.6c9
Finished processing dependencies for setuptools==0.6c9
Processing flup-1.0.2-py2.4.egg
Copying flup-1.0.2-py2.4.egg to /usr/lib/python2.4/site-packages
Adding flup 1.0.2 to easy-install.pth file
Installed /usr/lib/python2.4/site-packages/flup-1.0.2-py2.4.egg
Processing dependencies for flup==1.0.2
Finished processing dependencies for flup==1.0.2
12. 설치 성공 여부 검증
1. Nginx 프로필 다시 불 러 오기:
wget http://www.saddi.com/software/flup/dist/flup-1.0.2.tar.gz
tar zxvf flup-1.0.2.tar.gz
cd flup-1.0.2
python setup.py install

2. django 프로젝트 만 들 기
/usr/local/webserver/nginx/sbin/nginx -s reload

3. 클 라 이언 트 브 라 우 저 에 192.168.1.128 을 입력 하면 Django 프로젝트 'It worked!' 화면 을 볼 수 있 습 니 다.
메모: 접근 이 안 되면 방화벽 이 닫 히 지 않 았 을 수도 있 습 니 다. chkconfig iptables off service iptables stop

좋은 웹페이지 즐겨찾기