एक संभावित परिदृश्य:
कभी-कभी ऐसा हो सकता है कि, वर्चुअलहोस्ट के लिए SSL फाइल (निजी कुंजी और प्रमाण पत्र) को कॉन्फ़िगर करते समय जो कॉन्फ़िगर किया जा रहा है, यह उस पूर्ण पथ को निर्दिष्ट करने के लिए भूल गया जहां ये फाइलें निवास करती हैं।
उदाहरण के लिए, यदि आप Nginx से इस आधिकारिक दस्तावेज़ का पालन करते हैं: http://nginx.org/en/docs/http/configuring_https_servers.html
server {
listen 443 ssl;
server_name www.example.com;
ssl_certificate tdmssl.crt;
ssl_certificate_key tdmssl.key;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers HIGH:!aNULL:!MD5;
...
}
मान लीजिए कि आप SSL फ़ाइलों को " /etc/nginx/conf.d " के अंदर संग्रहीत करते हैं :
root@ilg40:/etc/nginx/conf.d# pwd
/etc/nginx/conf.d
root@ilg40:/etc/nginx/conf.d# ll
total 16
drwxr-xr-x 2 root root 4096 Jan 24 17:39 ./
drwxr-xr-x 5 root root 4096 Jan 24 21:15 ../
-rw-r--r-- 1 root root 1359 Jan 24 17:39 tdmssl.crt
-rw-r--r-- 1 root root 1675 Jan 24 17:39 tdmssl.key
क्या होता है?
डिफ़ॉल्ट रूप से, जब Nginx द्वारा उपयोग की जाने वाली साधारण फ़ाइल के लिए पूर्ण पथ निर्दिष्ट नहीं किया जाता है, तो Nginx "/ etc / nginx" पर फ़ाइलों की खोज करेगा
/Var/log/nginx/error.log से
2017/01/24 21:05:10 [emerg] 13113#0:
BIO_new_file("/etc/nginx/tdmssl.crt")
failed(SSL:error:02001002:system library:fopen:
No such file or directory:fopen('/etc/nginx/tdmssl.crt','r')
error:2006D080:BIO routines:BIO_new_file:no such file)
क्या करना होगा?
आपके वर्चुअलहोस्ट कॉन्फ़िगरेशन द्वारा उपयोग की जाने वाली अतिरिक्त फ़ाइलों के पूर्ण पथ को निर्दिष्ट करने के लिए।
ऐशे ही:
root@ilg40:/etc/nginx/conf.d# cd
root@ilg40:~# cat /etc/nginx/sites-available/tdm
server {
listen 443 ssl;
server_name tjsdatamanager.redtjs.com;
ssl_certificate /etc/nginx/conf.d/tdmssl.crt;
ssl_certificate_key /etc/nginx/conf.d/tdmssl.key;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_ciphers HIGH:!aNULL:!MD5;
location / {
include proxy_params;
proxy_pass http://unix:/etc/tdm/flask/wsgi.sock;
}
}
path/to/cert.pem
निश्चित रूप से एक वैध स्थान नहीं है।