.

ติดตั้ง NGINX (ดีกว่า Apache หรือ Lighttpd) - VPS ไบเบิล PT 11

English อังกฤษ (การเปลี่ยนแปลง)
  • Digg
  • Twitter
  • Technorati
  • del.icio.us
  • Facebook
  • MySpace
  • Reddit
  • StumbleUpon
  • LinkedIn
  • email

ตั้ง VPS Unmanaged (4 Newbies) - ส่วนที่ 11: Nginx (ดีกว่า Apache) Web Server

ติดตั้ง Nginx - Nginx logo

ติดตั้งและการกำหนดค่าเว็บเซิร์ฟเวอร์ Nginx, tweaking โครงสร้างแฟ้มปกติแล้วการตั้งค่าไฟล์ vhost กับ symlink เป็นเรื่องของการคัดลอกวาง / วิธีการนี้. เพื่อเปิดให้ CLI และฉันจะอธิบาย.

ดังนั้นเราจึงพร้อมที่จะติดตั้งแหล่งดาว, Nginx (เด่นชัด "เครื่องมือ-x"). แต่ทำไม? ไม่ Apache เว็บเซิร์ฟเวอร์ที่ดีที่สุด?

Apache ได้แสดงให้ฉันดีสำหรับปีทั้งในประเทศและในครอบครัวห่างไกลและยังคงเลือกที่น่าพอใจสำหรับเว็บไซต์ขนาดใหญ่หลาย.

แต่ kinda เช่นอูบุนตู, Firefox และ jQuery มีเด็กใหม่ในเมืองของและก็ leaner, ง่ายตั้งค่าและใช้และเร็วขึ้นเพื่อใช้. เข้าสู่เว็บเซิร์ฟเวอร์ Nginx.

ตั้ง VPS Unmanaged (4 Newbies) .. พระคัมภีร์ VPS

ใน 20 สำเนา / ขั้นตอนวาง .. จากศูนย์ให้พระเอกช่องว่างที่น่ารัก-เป็นเซิร์ฟเวอร์ Linux.

เลื่อนลงสำหรับดัชนีชุดเต็ม.

ดังนั้นเดี๋ยวก่อนโรงสาธารณะและขอให้มีอายุยืนยาวเสมือน! หวังช่วย. The_guv

Video: ติดตั้งและกำหนดค่า Nginx Web Server

ดูแล้วเอ้อ guvideo สำหรับแนวคิดที่ดีของการทำงานนี้.

ดูช่องทาง YouTube the_guv ของที่ http://youtube.com/guvnrDOTcom

... หรือถ้าคุณไม่สามารถ bothered กับที่หรือแม้ว่าคุณจะสามารถต่อไปนี้เป็นรายละเอียด ...

เลือก Nginx ทำไม ทำไมไม่ Apache หรือ Lighttpd?

ฉันไม่แสร้งเป็นผู้เชี่ยวชาญบางคนเพียงผู้วิจัยพ้นละเอียด. I ข้นหลักที่สองส่วนใหญ่นิยมที่ดีที่สุดตั้งเซิร์ฟเวอร์เว็บ Apache และ Lighttpd และทางเลือก Turk สาว Nginx เกี่ยวกับที่อยู่ geekdom ปลิวทั้งหมด. ต่อไปนี้เป็นสรุปผลที่สำคัญของฉัน: --

  • Apache เป็น bloatware, โหลดโมดูลที่ไม่ได้ใช้ทรัพยากรของเสีย
  • RAM leaks Lighttpd ไม่ดี
  • มาตรฐาน Nginx เร็วที่สุดโดยใช้ทรัพยากรอย่าง

ฉันใช้ไฟนี้ server น้ำหนักสำหรับทรัพยากรของฉันบล็อก WordPress หนัก guvnr.com และน. ประทับใจกับประสิทธิภาพของของแข็ง. ยังสำคัญไม่ได้ว่า Windows เหมือนแนวโน้ม, เสียใจ Apache เกินไปของการสูญเสียทรัพยากรโดยใช้เครือบริการที่ฉันไม่ต้อง.

ไม่ใช้คำพูดของฉันมัน. คุณไม่ควรเพราะฉันยังไม่ได้ดำเนินการทดสอบมาตรฐานใด. อย่าง Google เช่น Apache VS Nginx "หรือ Nginx VS Lighttpd และได้อ่าน. และนี่ของ Nginx Wiki.

รับล่าสุด Nginx Version

มีสองวิธีในการติดตั้งซอฟต์แวร์บน Linux จะใช้เครื่องมือติดตั้งรวมหรือมี sourcecode.

ปกติเราติดตั้งภายในโดยใช้สิ่งเช่นความถนัดติดตั้ง Linux 'แต่เนื่องจากนี้เช่นองค์ประกอบที่สำคัญของ VPS ของเราฉันจะแสดงวิธีการติดตั้งจากแหล่ง. วิธีการนี้จะใช้เวลานานหน่อยแต่คุ้มค่าเพราะเราจะมีมากขึ้นขึ้นไปรุ่นล่าสุด.

.. กับเว็บเซิร์ฟเวอร์เราไม่ควรตัดมุม. ที่จะเป็นเช่นซื้อสีเหลือง Ferrari.

ก่อนขึ้นเราต้องพึ่งพาบางไฟล์: --

sudo aptitude -y install libpcre3 libpcre3-dev libpcrecpp0 libssl-dev zlib1g-dev

And to create a directory in which to store the Nginx package:-

mkdir ~/sources

Change to that directory:-

cd ~/sources/

Now we get the latest stable Nginx release, nginx-0.7.62 *.

* As of September 2009, edited by the_guv. You should still check it is still the latest, here , and ammend the filename accordingly:-

wget http://sysoev.ru/nginx/nginx-0.7.62.tar.gz

Unzip it:-

tar -zxvf nginx-0.7.62.tar.gz

Go into the new unzipped folder:-

cd nginx-0.7.62

Installing and Testing Nginx

Compile with two options; where to install it, and including 'ssl' (to enable 'https' for secure connections, ie shopping and stuff):-

./configure --sbin-path=/usr/local/sbin --with-http_ssl_module

Install this baby:-

make
sudo make install

Kick it up:-

sudo /usr/local/sbin/nginx

And test it by popping your IP address in a web browser. You should see "Welcome to nginx!"

Now stop it:-

sudo kill `cat /usr/local/nginx/logs/nginx.pid`

Have Nginx Start, Restart or Stop When Required

This is important, for example, upon reboot. We need a script for this. Create a file:-

sudo nano /etc/init.d/nginx

And paste this within:-

#! /bin/sh

### BEGIN INIT INFO
# Provides:          nginx
# Required-Start:    $all
# Required-Stop:     $all
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: starts the nginx web server
# Description:       starts nginx using start-stop-daemon
### END INIT INFO

PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
DAEMON=/usr/local/sbin/nginx
NAME=nginx
DESC=nginx

test -x $DAEMON || exit 0

# Include nginx defaults if available
if [ -f /etc/default/nginx ] ; then
        . /etc/default/nginx
fi

set -e

case "$1" in
  start)
        echo -n "Starting $DESC: "
        start-stop-daemon --start --quiet --pidfile /usr/local/nginx/logs/$NAME.pid \
                --exec $DAEMON -- $DAEMON_OPTS
        echo "$NAME."
        ;;
  stop)
        echo -n "Stopping $DESC: "
        start-stop-daemon --stop --quiet --pidfile /usr/local/nginx/logs/$NAME.pid \
                --exec $DAEMON
        echo "$NAME."
        ;;

  restart|force-reload)
        echo -n "Restarting $DESC: "
        start-stop-daemon --stop --quiet --pidfile \
                /usr/local/nginx/logs/$NAME.pid --exec $DAEMON
        sleep 1
        start-stop-daemon --start --quiet --pidfile \
                /usr/local/nginx/logs/$NAME.pid --exec $DAEMON -- $DAEMON_OPTS
        echo "$NAME."
        ;;
  reload)
      echo -n "Reloading $DESC configuration: "
      start-stop-daemon --stop --signal HUP --quiet --pidfile /usr/local/nginx/logs/$NAME.pid \
          --exec $DAEMON
      echo "$NAME."
      ;;
  *)
        N=/etc/init.d/$NAME
        echo "Usage: $N {start|stop|restart|reload|force-reload}" >&2
        exit 1
        ;;
esac

exit 0

Then give the file permissions and make the script run on reboot, else start/stop/restart when required:-

sudo chmod +x /etc/init.d/nginx
sudo /usr/sbin/update-rc.d -f nginx defaults

nginx.conf - Configuring Nginx

Now open the Nginx configuration file:-

sudo nano /usr/local/nginx/conf/nginx.conf

...and strip out all the content, delete the lot. CTRL-K is the easy way to do that, if you were wondering.

And replace with this:-

user www-data www-data;
worker_processes  4;

events {
    worker_connections  1024;
}

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

    sendfile        on;
    tcp_nopush      on;
    tcp_nodelay     off;
    keepalive_timeout  5;

    gzip  on;
    gzip_comp_level 2;
    gzip_proxied any;
    gzip_types      text/plain text/css application/x-javascript text/xml application/xml application/xml+rss text/javascript;

    include /usr/local/nginx/sites-enabled/*;
}

Creating the Virtual Host File Structure & Symlinks

The Nginx file structure is pretty messy for multiple sites, so we'll sort that.

First, layout some new folders:-

sudo mkdir /usr/local/nginx/sites-available
sudo mkdir /usr/local/nginx/sites-enabled

...the first is for our virtual host (vhost) files, the second for their corresponding symlinks which will be referenced by Nginx' config file.

What are vhosts & symlinks?

You have one of each per domain, and one of each for the default settings.

The symlink, or symbolic link, references the web server to the virtual host file.

The vhost file is a configuration file. It tells the web server, for example, things like where the web files live or the kind of URI structure you want.

For now, we need a default vhost file, and that goes in the sites-available folder. So:-

sudo nano /usr/local/nginx/sites-available/default

Now paste this:-

server  {
            listen       80;
            server_name  localhost;
            
            location /  {
                    root   html;
                    index  index.php index.html index.htm;
       			   }
                       
            # redirect server error pages to the static page /50x.html
            error_page   500 502 503 504  /50x.html;
            location = /50x.html 
            		   {
            			root   html;
            		   }
		}

And enable it with this symlink:-

sudo ln -s /usr/local/nginx/sites-available/default /usr/local/nginx/sites-enabled/default

Boot it up again:-

sudo /etc/init.d/nginx start

...and check for that "Welcome..." page again, using your IP in a web browser.

Splendid. All pretty. And pretty well organised.

Moving Along

So that's Nginx up and running.

In Part 12 of this series Set Up an Unmanaged VPS (4 Newbies) I'm taking a quick detour, setting up FileZilla so we've got a Secure FTP (SFTP) connection. That'll be handy to help demonstrate Part 13, when we create another folder structure, this time for our sites and blogs, and pop up a couple of test pages.

Then, in Part 13, I'll show you how to use Subversion to more easily install and upgrade platforms and their modules/plugins. I'll example the popular WordPress scenario - and while we're about it we'll sort out WordPress caching and friendly-URLs.

And then, this, that, the other. Cue index ..


SETUP an Unmanaged VPS (4 Newbies) .. The V-P-S Bible

Serve multi sites & blogs on a budget .. at the fastest possible speed .. with the least downtime .. in the most secure environment .. and future-proofed for easy admin.

That's what the VPS Bible is about, stepped out in simple copy & paste guides.

From high traffic WordPress blogs to startup web hosts, here's what you need.

Set it up?   Click here for the 21 part follow-up .. V-P-S Admin

.