Otu esi etinye Yii PHP Framework na Ubuntu
Yii (akpọ Yee ma ọ bụ [ji:]) bụ isi mmalite mepere emepe, ngwa ngwa, arụmọrụ dị elu, nchekwa, na-agbanwe agbanwe ma na-arụ ọrụ nke ọma, yana usoro mmemme webụ zuru oke maka ịzụlite ụdị ngwa weebụ niile site na iji PHP.
N'edemede a, ị ga-amụta ka esi etinye usoro Yii kachasị ọhụrụ na Ubuntu LTS (nkwado ogologo oge) ka ịmalite ịmepụta ngwa weebụ PHP ọgbara ọhụrụ.
Yii na-ejide Ubuntu LTS (nkwado ogologo oge) ndị a:
- Ubuntu 20.04 LTS (Focal)
- Ubuntu 18.04 LTS (\Bionic)
- Ubuntu 16.04 LTS (\Xenial)
- Ihe atụ nke sava Ubuntu.
- Okpokoro LEMP nwere PHP 5.4.0 ma ọ bụ karịa.
- Onye dere – onye njikwa ngwugwu ọkwa ngwa maka PHP.
Na ibe a
- Ịwụnye Yii Framework site na Onye na-ede ihe na Ubuntu
- Na-eji PHP Mmepe Sava na-agba Yii
- Na-agba ọsọ Yii Project na Mmepụta Iji sava HTTP NGINX
- Kwado HTTPS na Ngwa Yii Iji Ka Anyị Encrypt
Enwere ụzọ abụọ iji wụnye Yii, site na iji njikwa ngwugwu Composer ma ọ bụ site na ịwụnye ya na faịlụ ebe nchekwa. Nke mbụ bụ ụzọ akwadoro, ebe ọ na-enyere gị aka ịwụnye mgbakwunye ọhụrụ ma ọ bụ melite Yii site na otu iwu.
Ọ bụrụ na ị nweghị onye na-ede egwú arụnyere, ị nwere ike ịwụnye ya site na iji iwu ndị a, nke ga-emecha wụnye Yii ma jikwaa ndabere ya.
$ curl -sS https://getcomposer.org/installer | php $ sudo mv composer.phar /usr/local/bin/composer $ sudo chmod +x /usr/local/bin/composer
Ozugbo etinyere onye na-ede egwú, banye na ndekọ /var/www/htm
nke ga-echekwa ngwa weebụ gị ma ọ bụ faịlụ webụsaịtị, wee wụnye ngwugwu Yii site na iji onye na-ede egwú (dochie testproject na aha nke gị). akwụkwọ ndekọ aha ngwa weebụ).
$ cd /var/www/html/ $ composer create-project --prefer-dist yiisoft/yii2-app-basic testproject
N'oge a, ị dịla njikere ịmalite iji usoro Yii maka mmepe. Iji mee ihe nkesa mmepe PHP, banye na ndekọ testprojects (aha ndekọ aha gị kwesịrị ịdị iche dabere na ihe ị kwuru na iwu gara aga), wee malite ihe nkesa mmepe. Site na ndabara, ọ ga-agba ọsọ na ọdụ ụgbọ mmiri 8080.
$ cd /var/www/html/testproject/ $ php yii serve
Iji mee ihe nkesa mmepe na ọdụ ụgbọ mmiri ọzọ, dịka ọmụmaatụ, ọdụ ụgbọ mmiri 5000, jiri ọkọlọtọ --port
dị ka egosiri.
$ php yii serve --port=5000
Mepee ihe nchọgharị weebụ gị wee gaa na iji adreesị a:
http://SERVER_IP:8080 OR http://SERVER_IP:5000
Iji bukwa ma nweta ngwa Yii na mmepụta, chọrọ ihe nkesa HTTP dị ka ngwanrọ sava weebụ akwadoro.
Iji nweta ngwa Yii na-enweghị ịpị ọdụ ụgbọ mmiri gị, ịkwesịrị ịmepụta DNS A
chọrọ ka ịdekọ ngalaba gị na sava ngwa Yii gị.
Maka ntuziaka a, anyị ga-egosi otu esi etinye ngwa Yii na NGINX. Yabụ, ịkwesịrị ịmepụta onye nnabata mebere ma ọ bụ faịlụ nhazi ihe nkesa n'okpuru /etc/nginx/sites-dị/ directory maka ngwa gị ka NGINX nwee ike ijere ya ozi.
$ sudo vim /etc/nginx/sites-available/testproject.me.conf
Detuo na mado nhazi ndị a na ya (dochie testprojects.me
na www.testprojects.me
na aha ngalaba gị). Kọwaa ụzọ NGINX ga-agafe arịrịọ FastCGI na PHP-FPM, na ihe atụ a, anyị na-eji oghere UNIX (/run/php/php7.4-fpm.sock):
server { set $host_path "/var/www/html/testproject"; #access_log /www/testproject/log/access.log main; server_name testprojects.me www.testprojects.me; root $host_path/web; set $yii_bootstrap "index.php"; charset utf-8; location / { index index.html $yii_bootstrap; try_files $uri $uri/ /$yii_bootstrap?$args; } location ~ ^/(protected|framework|themes/\w+/views) { deny all; } #avoid processing of calls to unexisting static files by yii location ~ \.(js|css|png|jpg|gif|swf|ico|pdf|mov|fla|zip|rar)$ { try_files $uri =404; } # pass the PHP scripts to FastCGI server listening on UNIX socket location ~ \.php { fastcgi_split_path_info ^(.+\.php)(.*)$; #let yii catch the calls to unexising PHP files set $fsn /$yii_bootstrap; if (-f $document_root$fastcgi_script_name){ set $fsn $fastcgi_script_name; } fastcgi_pass unix:/run/php/php7.4-fpm.sock; include fastcgi_params; fastcgi_param SCRIPT_FILENAME $document_root$fsn; #PATH_INFO and PATH_TRANSLATED can be omitted, but RFC 3875 specifies them for CGI fastcgi_param PATH_INFO $fastcgi_path_info; fastcgi_param PATH_TRANSLATED $document_root$fsn; } # prevent nginx from serving dotfiles (.htaccess, .svn, .git, etc.) location ~ /\. { deny all; access_log off; log_not_found off; } }
Chekwaa faịlụ ma mechie ya.
Wee lelee syntax nhazi NGINX maka izi ezi, ọ bụrụ na ọ dị mma, mee ka ngwa ọhụrụ ahụ dị ka egosiri:
$ sudo nginx -t $ sudo ln -s /etc/nginx/sites-available/testprojects.me.conf /etc/nginx/sites-enabled/testprojects.me.conf
Mgbe ahụ malitegharịa ọrụ NGINX ka itinye mgbanwe ọhụrụ:
$ sudo systemctl restart nginx
Gaa na ihe nchọgharị weebụ gị wee jiri aha ngalaba gị gaa.
http://testprojects.me OR http://www.testprojects.me
N'ikpeazụ, ịkwesịrị ịme HTTPS na webụsaịtị gị. Ị nwere ike iji akwụkwọ SSL/TLS na-akwụghị ụgwọ (nke ihe nchọgharị weebụ nke oge a na-akpaghị aka na ghọtara) ma ọ bụ nweta asambodo sitere na CA azụmahịa.
Ọ bụrụ n’ikpebie iji asambodo Let's Encrypt, enwere ike itinye ya na ahazi ya site na iji ngwa certbot. Iji wụnye certbot, ịkwesịrị ịwụnye snapd iji wụnye ya.
$ sudo snap install --classic certbot
Wee jiri certbot nweta ma wụnye/hazie asambodo SSL/TLS n'efu maka iji sava webụ NGINX (nye email ziri ezi maka mmeghari ohuru wee soro ntuziaka iji mezue nrụnye):
$ sudo certbot --nginx
Ugbu a gaa na ihe nchọgharị weebụ gị otu ugboro ọzọ iji gosi na ngwa Yii gị na-arụ ọrụ ugbu a na HTTPS (cheta HTTP kwesịrị ibugharị na HTTPS ozugbo).
http://testprojects.me OR http://www.testprojects.me
Maka ozi ndị ọzọ dị ka ijikọ ngwa gị na nchekwa data, lee akwụkwọ nhazi Yii sitere na webụsaịtị Yii ọrụ gọọmentị. Nwalee ma kesaa echiche gị gbasara Yii ma ọ bụ jụọ ajụjụ ọ bụla site na ụdị nzaghachi dị n'okpuru.