How to Setup a new Domain Name in NGINX - Golang Web Development

Опубликовано: 04 Октябрь 2024
на канале: Maharlikans Code
1,954
10

In this Golang Web Development Series #5, we're about to learn how to setup a new domain name in NGINX with Ubuntu 20.04 LTS server with step by step guide here in Golang's Web Development Series.

Get Linode Account:
https://www.linode.com/?r=6aae17162e9...

Maharlikans Code Github:
https://github.com/maharlikanscode/go...

#MaharlikansCode
#GolangWebDevelopment5
#SetupNewDomainInNGINX
#NGINX
#GolangTutorial
#LearnGolangWebDevelopment
#Golang
#LifeAsSoftwareDeveloper
#Maharlikans
#FilipinoSoftwareDeveloper

If you go with extra mile for buying me a cup of coffee, I appreciate it guys: https://ko-fi.com/maharlikanscode

Default:
# You should look at the following URL's in order to grasp a solid understanding
of Nginx configuration files in order to fully unleash the power of Nginx.
https://www.nginx.com/resources/wiki/...
https://www.nginx.com/resources/wiki/...
https://wiki.debian.org/Nginx/Directo...
# In most cases, administrators will remove this file from sites-enabled/ and
leave it as reference inside of sites-available where it will continue to be
updated by the nginx packaging team.
# This file will automatically load configuration files provided by other
applications, such as Drupal or Wordpress. These applications will be made
available underneath a path with that package name, such as /drupal8.
# Please see /usr/share/doc/nginx-doc/examples/ for more detailed examples.
# Default server configuration
server {
listen 80 default_server;
listen [::]:80 default_server;

# SSL configuration
# listen 443 ssl default_server;
listen [::]:443 ssl default_server;
# Note: You should disable gzip for SSL traffic.
See: https://bugs.debian.org/773332
# Read up on ssl_ciphers to ensure a secure configuration.
See: https://bugs.debian.org/765782
# Self signed certs generated by the ssl-cert package
Don't use them in a production server!
# include snippets/snakeoil.conf;

root /var/www/html;

Add index.php to the list if you are using PHP
index index.html index.htm index.nginx-debian.html;

server_name _;

location / {
First attempt to serve request as file, then
as directory, then fall back to displaying a 404.
try_files $uri $uri/ =404;
}

pass PHP scripts to FastCGI server
#
#location ~ \.php$ {
include snippets/fastcgi-php.conf;
# # With php-fpm (or other unix sockets):
fastcgi_pass unix:/var/run/php/php7.4-fpm.sock;
# With php-cgi (or other tcp sockets):
fastcgi_pass 127.0.0.1:9000;
#}

deny access to .htaccess files, if Apache's document root
concurs with nginx's one
#
#location ~ /\.ht {
deny all;
#}
}

Virtual Host configuration for example.com
# You can move that to a different file under sites-available/ and symlink that
to sites-enabled/ to enable it.
#
#server {
listen 80;
listen [::]:80;
# server_name example.com;
# root /var/www/example.com;
index index.html;
# location / {
try_files $uri $uri/ =404;
}
#}

maharlikanscode.com:
server {
listen 80;

SSL configuration
# listen 443 ssl default_server;
listen [::]:443 ssl default_server;
# Note: You should disable gzip for SSL traffic.
See: https://bugs.debian.org/773332
# Read up on ssl_ciphers to ensure a secure configuration.
See: https://bugs.debian.org/765782
# Self signed certs generated by the ssl-cert package
Don't use them in a production server!
# include snippets/snakeoil.conf;

Add index.php to the list if you are using PHP
index index.html index.htm index.nginx-debian.html;

server_name maharlikanscode.com www.maharlikanscode.com;
root /var/www/html/maharlikanscode.com/public_html;

location / {
First attempt to serve request as file, then
as directory, then fall back to displaying a 404.
try_files $uri $uri/ =404;
}

pass PHP scripts to FastCGI server
#
#location ~ \.php$ {
include snippets/fastcgi-php.conf;
# # With php-fpm (or other unix sockets):
fastcgi_pass unix:/var/run/php/php7.4-fpm.sock;
# With php-cgi (or other tcp sockets):
fastcgi_pass 127.0.0.1:9000;
#}

location /static/ {
alias /var/www/html/maharlikanscode.com/public_html/static/;
}

location ~* \.(jpg|jpeg|png|gif|ico|css|js|pdf|ttf|ttc|otf|eot|woff|woff2)$ {
expires 7d;
add_header Access-Control-Allow-Origin *;
}

deny access to .htaccess files, if Apache's document root
concurs with nginx's one
location ~ /\. {
access_log off;
log_not_found off;
deny all;
}
}