Thứ Hai, 15 tháng 1, 2018

Hướng dẫn cài đặt Nginx trên Windows

Trong giai đoạn nghiên cứu về hệ thống có tính sẵn sàng cao (High Available System) thì tôi bắt đầu tìm hiểu về Nginx và thực hành cài cấu trên Windows. Mục đích là nghiên cứu thử nghiệm, do đó bài này tôi sẽ note lại làm tài liệu tham khảo cho các bạn.
Việc cài đặt Nginx trên Windows cực kỳ đơn giản. Bản tải xuống phiên bản dành cho Windows tại đây. Phiên bản hiện tại là 1.7.3. Sau đó, thực hiện giải nén vào thư mục  nginx-1.7.3 , và khởi chạy  nginx . Đây là trường hợp tôi cài nginx vào thư mục  C:\opt\nginx-1.7.3 
1
2
3
4
cd C:\opt
unzip nginx-1.7.3.zip
cd nginx-1.7.3
start nginx
Kiểm tra quá trình cài đặt và khởi chạy thành công, sử dụng lệnh sau đây:
1
2
3
4
5
6
C:\opt\nginx-1.7.3>tasklist /fi "imagename eq nginx.exe"
 
Image Name           PID Session Name     Session#    Mem Usage
=============== ======== ============== ========== ============
nginx.exe            652 Console                 0      2 780 K
nginx.exe           1332 Console                 0      3 112 K
Như trên là có 1 master process, 1 là worker process. Nếu Nginx không start, hãy kiểm tra nguyên nhân trong file  logs\error.log . Nếu file log không được tạo, nguyên có thể được cảnh báo trong Windows Event Log.
nginx/Windows mặc định sử dụng cấu hình đường dẫn tương đối với thư mục khởi chạy. Trong ví dụ trên, đường dẫn tương đối được đặt tại  C:\opt\nginx-1.7.3  Đường dẫn cấu hình được định dạng theo UNIX-style với dấu sổ chéo ngược. Xem file cấu hình  config\nginx.conf 
1
2
access_log   logs/site.log;
root         C:/web/html;
nginx/Windows chạy dưới dạng ứng dụng console (không phải là service), và được quản lý bởi các lệnh sau đây:
  • nginx -s stop fast shutdown
  • nginx -s quit graceful shutdown
  • nginx -s reload changing configuration, starting new worker processes with a new configuration, graceful shutdown of old worker processes
  • nginx -s reopen re-opening log files

Các vấn đề cần cài cấu, chỉnh sửa

  • Mặc dù có nhiều worker chạy, chỉ có 1 trong số chúng thực sự làm việc
  • Một Worker không thể xử lý nhiều hơn 1024 kết nối đồng thời
Nguồn: http://how.vndemy.com/software/333-huong-dan-cai-dat-nginx-tren-windows/

Configure Virtual Hosts on Xamp

Apache makes it easy to have multiple websites or web applications running on the same physical server, and access each using a custom domain name. This is known as virtual hosting, and each virtual host can be mapped to a different subdirectory of the server.
This feature is especially useful in development scenarios, as it allows developers to isolate and access different applications using unique domain names. For example, the domains http://app01.localhost and http://app02.localhost could point to two separate applications on the same server. Or, you could create separate domains, such as http://client1/http://client2/ and so on, for multiple client websites hosted on the same server.

Virtual hosts created in this manner will not be accessible from other systems, unless those systems are separately configured to associate the custom domain used by the virtual host with the IP address of the XAMPP server. This guide walks you through the process of setting up a new virtual host with XAMPP, by creating and configuring an example host named wordpress.localhost for a WordPress installation. It assumes that you have an existing WordPress installation at /opt/lampp/apps/wordpress/htdocs/ and accessible via the URL http://localhost/wordpress.
You can install WordPress with just a few clicks using the Bitnami WordPress Module for XAMPP.
Follow the steps below to create a virtual host:
  1. Open a new Linux terminal and ensure you are logged in as root.
  2. Change to your XAMPP installation directory (typically, /opt/lampp) and open the httpd.conf file in the etc/ subdirectory using a text editor.
  3. Within the file, find the following line and uncomment it by removing the hash symbol (#) at the beginning of the line.
    Include etc/extra/httpd-vhosts.conf


Next, open the httpd-vhosts.conf file in the etc/extra/ subdirectory of your XAMPP installation directory. Replace the contents of this file with the following directives:
<VirtualHost *:80>
       DocumentRoot "/opt/lampp/htdocs/"
       ServerName localhost
</VirtualHost>
<VirtualHost *:80>
       DocumentRoot "/opt/lampp/apps/wordpress/htdocs"
       ServerName wordpress.localhost
</VirtualHost>
This contains two virtual host configuration blocks:
  • The first block is the default or fallback virtual host, which is used for all requests that are not matched by subsequent blocks.
  • The second block sets up a virtual host named wordpress.localhost. The DocumentRoot directive specifies the directory to be used when serving requests for this virtual host (in this case, the WordPress installation directory), while the ServerName directive specifies the custom domain name for the virtual host.
To add more virtual hosts, simply duplicate the second virtual host block and modify the port number, DocumentRoot and ServerName directives as per your requirements. For example, if you want to use SSL with your custom domain name, you can add a new virtual host block for port 443.
If you plan to have a large number of virtual hosts with very similar configuration, consider using wildcard-based subdomains with your virtual hosts.
Restart Apache using the XAMPP control panel for your changes to take effect.

At this point, your virtual host is configured. However, if you try browsing to the wordpress.localhost domain, your browser will show a failure notice, since this domain does not exist in reality. To resolve this, it is necessary to map the custom domain to the local IP address. To do this, open the /etc/hosts file and add the following line to it:
127.0.0.1           wordpress.localhost
  1. This takes care of mapping the wordpress.localhost domain name to the local machine, which always has the IP address 127.0.0.1.
At this point, you should be able to enter the URL http://wordpress.localhost in your browser’s address bar and see your WordPress installation. Here’s an example of what you should see: