Setting up SFTP with Nginx: Difference between revisions
Jump to navigation
Jump to search
(Created page with " = Nginx Directory Permissions and Symbolic Link Configuration Guide = == Environment Overview == * Using SFTP to upload files to personal directory * Personal directory linked to website root via symbolic link * Files accessible through public web URL after upload === Example SFTP Upload Process === # Upload file to personal directory: <code>/home/your_user/public_folder/</code> # File automatically reflects in website directory: <code>/usr/share/nginx/html/folder/...") |
mNo edit summary |
||
| Line 27: | Line 27: | ||
<li>Check Directory Structure and Permissions</li></ol> | <li>Check Directory Structure and Permissions</li></ol> | ||
< | <pre lang="bash"># Check website root directory | ||
sudo ls -lht /usr/share/nginx/html/ | sudo ls -lht /usr/share/nginx/html/ | ||
# Check target directory | # Check target directory | ||
sudo ls -lht /usr/share/nginx/html/folder/</ | sudo ls -lht /usr/share/nginx/html/folder/</pre> | ||
<ol start="3" style="list-style-type: decimal;"> | <ol start="3" style="list-style-type: decimal;"> | ||
<li>Check Nginx Configuration</li></ol> | <li>Check Nginx Configuration</li></ol> | ||
< | <pre lang="bash"># Check nginx config | ||
sudo nano /etc/nginx/nginx.conf | sudo nano /etc/nginx/nginx.conf | ||
# Or check site config | # Or check site config | ||
sudo nano /etc/nginx/sites-available/default</ | sudo nano /etc/nginx/sites-available/default</pre> | ||
Basic nginx configuration should include: | Basic nginx configuration should include: | ||
< | <pre lang="nginx">server { | ||
listen 80; | listen 80; | ||
server_name your_domain; | server_name your_domain; | ||
| Line 50: | Line 50: | ||
try_files $uri $uri/ =404; | try_files $uri $uri/ =404; | ||
} | } | ||
}</ | }</pre> | ||
<span id="common-issues"></span> | <span id="common-issues"></span> | ||
== Common Issues: == | == Common Issues: == | ||
| Line 62: | Line 62: | ||
# Check Nginx Error Log | # Check Nginx Error Log | ||
< | <pre lang="bash">sudo tail /var/log/nginx/error.log</pre> | ||
Possible error message: | Possible error message: | ||
| Line 69: | Line 69: | ||
<li>Set User Directory Permissions</li></ol> | <li>Set User Directory Permissions</li></ol> | ||
< | <pre lang="bash"># Ensure user directory is accessible | ||
sudo chmod 755 /home/your_user</ | sudo chmod 755 /home/your_user</pre> | ||
<ol start="3" style="list-style-type: decimal;"> | <ol start="3" style="list-style-type: decimal;"> | ||
<li>Set Website Directory Permissions</li></ol> | <li>Set Website Directory Permissions</li></ol> | ||
< | <pre lang="bash"># Ensure website directory is accessible | ||
sudo chmod 755 /home/your_user/public_folder</ | sudo chmod 755 /home/your_user/public_folder</pre> | ||
<ol start="4" style="list-style-type: decimal;"> | <ol start="4" style="list-style-type: decimal;"> | ||
<li>(optional) Set File Permissions</li></ol> | <li>(optional) Set File Permissions</li></ol> | ||
< | <pre lang="bash"># Set file read permissions | ||
chmod 644 /usr/share/nginx/html/folder/your_file.png</ | chmod 644 /usr/share/nginx/html/folder/your_file.png</pre> | ||
<span id="permission-details"></span> | <span id="permission-details"></span> | ||
== Permission Details == | == Permission Details == | ||
| Line 98: | Line 98: | ||
<li><p>Public URL format: <nowiki>http://your_domain/folder/file.png</nowiki></p></li> | <li><p>Public URL format: <nowiki>http://your_domain/folder/file.png</nowiki></p></li> | ||
<li><p>If still inaccessible after configuration:</p> | <li><p>If still inaccessible after configuration:</p> | ||
< | <pre lang="bash"># Reload nginx configuration | ||
sudo systemctl reload nginx</ | sudo systemctl reload nginx</pre></li></ol> | ||
== Important Notes == | == Important Notes == | ||
Revision as of 14:05, 22 January 2025
Nginx Directory Permissions and Symbolic Link Configuration Guide
Environment Overview
- Using SFTP to upload files to personal directory
- Personal directory linked to website root via symbolic link
- Files accessible through public web URL after upload
Example SFTP Upload Process
- Upload file to personal directory:
/home/your_user/public_folder/ - File automatically reflects in website directory:
/usr/share/nginx/html/folder/ - Access via URL: http://your_domain/folder/file.png
Configuration Steps
- Verify Symbolic Link
# Check if symbolic link is correct
ls -l /home/your_user/public_folderExpected output:
lrwxrwxrwx 1 your_user your_user 26 Jan 20 15:00 /home/your_user/public_folder -> /usr/share/nginx/html/folder
- Check Directory Structure and Permissions
# Check website root directory
sudo ls -lht /usr/share/nginx/html/
# Check target directory
sudo ls -lht /usr/share/nginx/html/folder/
- Check Nginx Configuration
# Check nginx config
sudo nano /etc/nginx/nginx.conf
# Or check site config
sudo nano /etc/nginx/sites-available/default
Basic nginx configuration should include:
server {
listen 80;
server_name your_domain;
root /usr/share/nginx/html;
index index.html;
location / {
try_files $uri $uri/ =404;
}
}
Common Issues:
- Specific directories return 404 (files exist)
- Files uploaded via SFTP not accessible via web
- Nginx error log shows permission issues
Solution: Adjust Permission Settings
- Check Nginx Error Log
sudo tail /var/log/nginx/error.log
Possible error message:
[crit] stat() "[path]/file.png" failed (13: Permission denied)
- Set User Directory Permissions
# Ensure user directory is accessible
sudo chmod 755 /home/your_user
- Set Website Directory Permissions
# Ensure website directory is accessible
sudo chmod 755 /home/your_user/public_folder
- (optional) Set File Permissions
# Set file read permissions
chmod 644 /usr/share/nginx/html/folder/your_file.png
Permission Details
chmod 755(directories):- Owner: read, write, execute (rwx)
- Group: read and execute (r-x)
- Others: read and execute (r-x)
chmod 644(files):- Owner: read, write (rw-)
- Group: read (r–)
- Others: read (r–)
Testing and Verification
Public URL format: http://your_domain/folder/file.png
If still inaccessible after configuration:
# Reload nginx configuration sudo systemctl reload nginx
Important Notes
- Permission changes take effect immediately, no nginx restart needed
- Entire path needs proper execute permissions
- New files need correct permissions set
- Ensure symbolic links remain intact
- Verify files are uploaded to correct location