Nginx + Django + fastcgi 서버 환경 구축
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
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Django의 질문 및 답변 웹사이트환영 친구, 이것은 우리의 새로운 블로그입니다. 이 블로그에서는 , 과 같은 Question-n-Answer 웹사이트를 만들고 있습니다. 이 웹사이트는 회원가입 및 로그인이 가능합니다. 로그인 후 사용자는 사용자의 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.