{"id":16542,"date":"2024-01-26T17:30:19","date_gmt":"2024-01-26T14:00:19","guid":{"rendered":"https:\/\/rasanegar.com\/blog\/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-deployment-%d8%a8%d9%87-%d9%82%d8%b3%d9%85%d8%aa-%d9%87\/"},"modified":"2024-01-26T17:30:19","modified_gmt":"2024-01-26T14:00:19","slug":"%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-deployment-%d8%a8%d9%87-%d9%82%d8%b3%d9%85%d8%aa-%d9%87","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-deployment-%d8%a8%d9%87-%d9%82%d8%b3%d9%85%d8%aa-%d9%87\/","title":{"rendered":"\u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u062a\u06a9 \u0635\u0641\u062d\u0647 \u0627\u06cc \u0628\u0627 Vue.js \u0648 Flask: Deployment \u0628\u0647 \u0642\u0633\u0645\u062a \u0647\u0641\u062a\u0645 \u0648 \u0622\u062e\u0631 \u0627\u06cc\u0646 \u0645\u062c\u0645\u0648\u0639\u0647 \u0622\u0645\u0648\u0632\u0634\u06cc \u0686\u0646\u062f \u0642\u0633\u0645\u062a\u06cc \u062e\u0648\u0634 \u0622\u0645\u062f\u06cc\u062f \u0631\u0648\u06cc \u062a\u0648\u0633\u0639\u0647 \u0648\u0628 \u062a\u0645\u0627\u0645 \u067e\u0634\u062a\u0647 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Vue.js \u0648 Flask.  \u062f\u0631 \u0627\u06cc\u0646 \u067e\u0633\u062a \u0631\u0648\u0634 \u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u0633\u0627\u062e\u062a\u0647 \u0634\u062f\u0647 \u062f\u0631 \u0627\u06cc\u0646 \u0633\u0631\u06cc \u0631\u0627 \u0646\u0634\u0627\u0646 \u062e\u0648\u0627\u0647\u0645 \u062f\u0627\u062f.  \u06a9\u062f \u0627\u06cc\u0646 \u067e\u0633\u062a \u0631\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u067e\u06cc\u062f\u0627 \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc \u062d\u0633\u0627\u0628 GitHub \u0645\u0646 \u062a\u062d\u062a &#8230;"},"content":{"rendered":"<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_85 counter-hierarchy ez-toc-counter ez-toc-custom ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\"><p class=\"ez-toc-title\" style=\"cursor:inherit\">\u0633\u0631\u0641\u0635\u0644\u0647\u0627\u06cc \u0645\u0637\u0644\u0628<\/p>\n<\/div><nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-deployment-%d8%a8%d9%87-%d9%82%d8%b3%d9%85%d8%aa-%d9%87\/#%d8%a7%d8%b3%d8%aa%d9%82%d8%b1%d8%a7%d8%b1_%d8%af%d8%b1_%db%8c%da%a9_%d8%b3%d8%b1%d9%88%d8%b1_%d8%ae%d8%b5%d9%88%d8%b5%db%8c_%d9%85%d8%ac%d8%a7%d8%b2%db%8c\" >\u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u062f\u0631 \u06cc\u06a9 \u0633\u0631\u0648\u0631 \u062e\u0635\u0648\u0635\u06cc \u0645\u062c\u0627\u0632\u06cc<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-deployment-%d8%a8%d9%87-%d9%82%d8%b3%d9%85%d8%aa-%d9%87\/#%d9%85%d8%ad%d8%aa%d9%88%d8%a7%db%8c_%d8%b3%d8%b1%db%8c\" >\u0645\u062d\u062a\u0648\u0627\u06cc \u0633\u0631\u06cc<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-deployment-%d8%a8%d9%87-%d9%82%d8%b3%d9%85%d8%aa-%d9%87\/#%d9%85%d8%b1%d9%88%d8%b1%db%8c_%d8%a8%d8%b1_%d9%81%d9%86%d8%a7%d9%88%d8%b1%db%8c_%d9%87%d8%a7\" >\u0645\u0631\u0648\u0631\u06cc \u0628\u0631 \u0641\u0646\u0627\u0648\u0631\u06cc \u0647\u0627<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-deployment-%d8%a8%d9%87-%d9%82%d8%b3%d9%85%d8%aa-%d9%87\/#%d8%a2%d9%85%d8%a7%d8%af%d9%87_%d8%b4%d8%af%d9%86_%da%a9%d8%af_%d8%a8%d8%b1%d8%a7%db%8c_%d8%a7%d8%b3%d8%aa%d9%82%d8%b1%d8%a7%d8%b1\" >\u0622\u0645\u0627\u062f\u0647 \u0634\u062f\u0646 \u06a9\u062f \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0642\u0631\u0627\u0631<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-deployment-%d8%a8%d9%87-%d9%82%d8%b3%d9%85%d8%aa-%d9%87\/#%d8%af%d8%b1_%d8%ad%d8%a7%d9%84_%d8%a2%d9%85%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%d8%b3%d8%b1%d9%88%d8%b1_%d8%a7%d9%88%d8%a8%d9%88%d9%86%d8%aa%d9%88\" >\u062f\u0631 \u062d\u0627\u0644 \u0622\u0645\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0633\u0631\u0648\u0631 \u0627\u0648\u0628\u0648\u0646\u062a\u0648<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-deployment-%d8%a8%d9%87-%d9%82%d8%b3%d9%85%d8%aa-%d9%87\/#%d8%b1%d8%a7%d9%87_%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c_uwsgi_container_%d8%b3%d8%b1%d9%88%d8%b1\" >\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc uWSGI Container \u0633\u0631\u0648\u0631<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-deployment-%d8%a8%d9%87-%d9%82%d8%b3%d9%85%d8%aa-%d9%87\/#%d8%b1%d8%a7%d9%87_%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c_nginx\" >\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc Nginx<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-deployment-%d8%a8%d9%87-%d9%82%d8%b3%d9%85%d8%aa-%d9%87\/#%d9%86%d8%aa%db%8c%d8%ac%d9%87\" >\u0646\u062a\u06cc\u062c\u0647<\/a><\/li><\/ul><\/nav><\/div>\n<span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 8<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span><p> <br \/>\n<\/p>\n<div class=\"content\"><noscript><\/p>\n<style>.lazyload-placeholder { display: none;  }<\/style>\n<p><\/noscript><\/p>\n<h2 id=\"deploymenttoavirtualprivateserver\"><span class=\"ez-toc-section\" id=\"%d8%a7%d8%b3%d8%aa%d9%82%d8%b1%d8%a7%d8%b1_%d8%af%d8%b1_%db%8c%da%a9_%d8%b3%d8%b1%d9%88%d8%b1_%d8%ae%d8%b5%d9%88%d8%b5%db%8c_%d9%85%d8%ac%d8%a7%d8%b2%db%8c\"><\/span>\u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u062f\u0631 \u06cc\u06a9 \u0633\u0631\u0648\u0631 \u062e\u0635\u0648\u0635\u06cc \u0645\u062c\u0627\u0632\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0647 \u0642\u0633\u0645\u062a \u0647\u0641\u062a\u0645 \u0648 \u0622\u062e\u0631 \u0627\u06cc\u0646 \u0645\u062c\u0645\u0648\u0639\u0647 \u0622\u0645\u0648\u0632\u0634\u06cc \u0686\u0646\u062f \u0642\u0633\u0645\u062a\u06cc \u062e\u0648\u0634 \u0622\u0645\u062f\u06cc\u062f \u0631\u0648\u06cc \u062a\u0648\u0633\u0639\u0647 \u0648\u0628 \u062a\u0645\u0627\u0645 \u067e\u0634\u062a\u0647 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Vue.js \u0648 Flask.  \u062f\u0631 \u0627\u06cc\u0646 \u067e\u0633\u062a \u0631\u0648\u0634 \u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u0633\u0627\u062e\u062a\u0647 \u0634\u062f\u0647 \u062f\u0631 \u0627\u06cc\u0646 \u0633\u0631\u06cc \u0631\u0627 \u0646\u0634\u0627\u0646 \u062e\u0648\u0627\u0647\u0645 \u062f\u0627\u062f.<\/p>\n<p>\u06a9\u062f \u0627\u06cc\u0646 \u067e\u0633\u062a \u0631\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u067e\u06cc\u062f\u0627 \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc \u062d\u0633\u0627\u0628 GitHub \u0645\u0646 \u062f\u0631 \u0632\u06cc\u0631 \u0634\u0627\u062e\u0647 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/github.com\/amcquistan\/flask-vuejs-survey\/tree\/SeventhPost\">\u067e\u0633\u062a \u0647\u0641\u062a\u0645<\/a>.<\/p>\n<h2 id=\"seriescontent\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%ad%d8%aa%d9%88%d8%a7%db%8c_%d8%b3%d8%b1%db%8c\"><\/span>\u0645\u062d\u062a\u0648\u0627\u06cc \u0633\u0631\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<ol>\n<li>\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0648 \u0622\u0634\u0646\u0627\u06cc\u06cc \u0628\u0627 VueJS<\/li>\n<li>\u0645\u0633\u06cc\u0631\u06cc\u0627\u0628 Vue<\/li>\n<li>\u0645\u062f\u06cc\u0631\u06cc\u062a \u062f\u0648\u0644\u062a\u06cc \u0628\u0627 Vuex<\/li>\n<li>RESTful API \u0628\u0627 Flask<\/li>\n<li>\u0627\u062f\u063a\u0627\u0645 AJAX \u0628\u0627 REST API<\/li>\n<li>\u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a JWT<\/li>\n<li>\u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u062f\u0631 \u06cc\u06a9 \u0633\u0631\u0648\u0631 \u062e\u0635\u0648\u0635\u06cc \u0645\u062c\u0627\u0632\u06cc <em>(\u062a\u0648 \u0627\u06cc\u0646\u062c\u0627\u06cc\u06cc)<\/em><\/li>\n<\/ol>\n<h2 id=\"overviewofthetechnologies\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%b1%d9%88%d8%b1%db%8c_%d8%a8%d8%b1_%d9%81%d9%86%d8%a7%d9%88%d8%b1%db%8c_%d9%87%d8%a7\"><\/span>\u0645\u0631\u0648\u0631\u06cc \u0628\u0631 \u0641\u0646\u0627\u0648\u0631\u06cc \u0647\u0627<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u06cc\u0646 \u0622\u0645\u0648\u0632\u0634 \u0686\u0646\u062f\u06cc\u0646 \u0641\u0646\u0627\u0648\u0631\u06cc \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u06cc\u06a9 Flask REST API \u0686\u0646\u062f \u0644\u0627\u06cc\u0647 \u062a\u0648\u0632\u06cc\u0639 \u0634\u062f\u0647 \u0648 \u0628\u0631\u0646\u0627\u0645\u0647 Vue.js SPA \u0631\u0627 \u067e\u0648\u0634\u0634 \u062e\u0648\u0627\u0647\u062f \u062f\u0627\u062f.  \u062f\u0631 \u0632\u06cc\u0631 \u0645\u0646 \u0641\u0646\u0627\u0648\u0631\u06cc \u0647\u0627 \u0648 \u06a9\u0627\u0631\u0628\u0631\u062f \u0622\u0646\u0647\u0627 \u0631\u0627 \u0644\u06cc\u0633\u062a \u06a9\u0631\u062f\u0647 \u0627\u0645:<\/p>\n<ul>\n<li>\u0627\u0648\u0628\u0648\u0646\u062a\u0648 LTS 16.04: host \u0633\u0631\u0648\u0631 \u0628\u0631\u0627\u06cc \u0627\u062c\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627 \u0648 \u0633\u0631\u0648\u0631\u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641<\/li>\n<li>uWSGI: \u0631\u0627\u0628\u0637 \u062f\u0631\u0648\u0627\u0632\u0647 \u0648\u0628 \u0633\u0631\u0648\u0631 (WSGI) container \u0633\u0631\u0648\u0631 \u0628\u0631\u0627\u06cc \u0627\u062c\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u067e\u0627\u06cc\u062a\u0648\u0646 (\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0648\u0631\u062f \u0641\u0644\u0627\u0633\u06a9)<\/li>\n<li>Nginx: \u0648\u0628 \u0633\u0631\u0648\u0631 HTTP \u063a\u06cc\u0631 \u0645\u0633\u062f\u0648\u062f \u06a9\u0646\u0646\u062f\u0647 \u0628\u0627 \u0639\u0645\u0644\u06a9\u0631\u062f \u0628\u0627\u0644\u0627 \u06a9\u0647 \u0642\u0627\u062f\u0631 \u0628\u0647 \u067e\u0631\u0648\u06a9\u0633\u06cc \u0645\u0639\u06a9\u0648\u0633 \u0628\u0647 uWSGI \u0627\u0633\u062a.<\/li>\n<li>Node.js \/ NPM: \u0645\u062d\u06cc\u0637 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0628\u0631\u0627\u06cc \u0633\u0627\u062e\u062a \u0628\u0631\u0646\u0627\u0645\u0647 Vue.js SPA<\/li>\n<\/ul>\n<h2 id=\"gettingthecodereadyfordeployment\"><span class=\"ez-toc-section\" id=\"%d8%a2%d9%85%d8%a7%d8%af%d9%87_%d8%b4%d8%af%d9%86_%da%a9%d8%af_%d8%a8%d8%b1%d8%a7%db%8c_%d8%a7%d8%b3%d8%aa%d9%82%d8%b1%d8%a7%d8%b1\"><\/span>\u0622\u0645\u0627\u062f\u0647 \u0634\u062f\u0646 \u06a9\u062f \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0642\u0631\u0627\u0631<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0686\u0646\u062f \u062a\u063a\u06cc\u06cc\u0631 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0628\u0627\u06cc\u062f \u062f\u0631 \u06a9\u062f \u0627\u06cc\u062c\u0627\u062f \u0634\u0648\u062f \u062a\u0627 \u067e\u0633 \u0627\u0632 \u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u062f\u0631 \u0645\u062d\u06cc\u0637 \u062a\u0648\u0644\u06cc\u062f \u0645\u0646\u060c \u0642\u0627\u0628\u0644 \u0646\u06af\u0647\u062f\u0627\u0631\u06cc \u062a\u0631 \u0634\u0648\u062f.<\/p>\n<p>\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u062f\u0631 <code>api\/index.js<\/code> \u0627\u0632 <code>survey-spa<\/code> \u0628\u0631\u0646\u0627\u0645\u0647 Vue.js \u0645\u0646 \u0645\u062a\u063a\u06cc\u0631\u06cc \u0631\u0627 \u06a9\u062f\u06af\u0630\u0627\u0631\u06cc \u06a9\u0631\u062f\u0647 \u0627\u0645 \u0628\u0647 \u0646\u0627\u0645 <code>API_URL<\/code> \u0628\u0631\u0627\u06cc \u0627\u0634\u0627\u0631\u0647 \u0628\u0647 \u0633\u0631\u0648\u0631 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u0647 <code>http:\/\/127.0.0.1:5000\/api<\/code>.  \u0628\u0627 \u0627\u0646\u062c\u0627\u0645 \u0627\u06cc\u0646 \u06a9\u0627\u0631\u060c \u0628\u0627\u06cc\u062f \u0628\u0647 \u062e\u0627\u0637\u0631 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0645 \u06a9\u0647 \u0647\u0631 \u0628\u0627\u0631 \u06a9\u0647 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u062f\u0627\u0631\u0645\u060c \u0627\u06cc\u0646 \u0622\u062f\u0631\u0633 IP \u0633\u0631\u0648\u0631 \u062a\u0648\u0644\u06cc\u062f \u0631\u0627 \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0647\u0645.<\/p>\n<p>\u062a\u062c\u0631\u0628\u0647 \u0628\u0647 \u0645\u0646 \u0622\u0645\u0648\u062e\u062a\u0647 \u0627\u0633\u062a \u06a9\u0647 \u0647\u0645\u06cc\u0634\u0647 \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a\u06cc \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u062c\u0648\u062f \u062e\u0648\u0627\u0647\u062f \u062f\u0627\u0634\u062a \u06a9\u0647 \u0645\u0633\u062a\u0644\u0632\u0645 \u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u062f\u0631 \u0622\u06cc\u0646\u062f\u0647 \u0627\u0633\u062a\u060c \u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0627\u062d\u062a\u0645\u0627\u0644\u0627 \u0641\u0631\u0627\u0645\u0648\u0634 \u0645\u06cc \u06a9\u0646\u0645 \u0627\u06cc\u0646 \u0622\u062f\u0631\u0633 IP \u0631\u0627 \u0628\u0647 \u0631\u0648\u0632 \u06a9\u0646\u0645.  \u06cc\u06a9 \u0631\u0648\u0634 \u0628\u0647\u062a\u0631 \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u062e\u0637\u0631 \u0641\u0631\u0627\u0645\u0648\u0634\u06cc \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u0627\u06cc\u0646 \u0645\u0648\u0631\u062f \u0631\u0627 \u0627\u0632 \u0628\u06cc\u0646 \u0628\u0628\u0631\u0645 \u0648 \u062f\u0631 \u0639\u0648\u0636 \u0627\u0632 \u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u062f\u0631 \u0633\u0627\u062e\u062a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0645. process \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0628\u0631\u0627\u06cc \u0645\u0646 \u0648 \u062f\u0631 \u0646\u062a\u06cc\u062c\u0647 \u06a9\u0645\u062a\u0631 \u0686\u06cc\u0632\u06cc \u0631\u0627 \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0628\u0647 \u062e\u0627\u0637\u0631 \u0628\u0633\u067e\u0627\u0631\u0645 (\u06cc\u0639\u0646\u06cc \u0645\u0631\u0627\u062d\u0644 \u06a9\u0645\u062a\u0631\u06cc \u0646\u06cc\u0627\u0632 \u0627\u0633\u062a) \u062f\u0631 \u0637\u0648\u0644 \u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0645.  \u0627\u06cc\u0646 \u0628\u0647 \u0637\u0648\u0631 \u0642\u0627\u0628\u0644 \u062a\u0648\u062c\u0647\u06cc \u062e\u0637\u0631 \u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u0646\u0627\u0645\u0648\u0641\u0642 \u0631\u0627 \u06a9\u0627\u0647\u0634 \u0645\u06cc \u062f\u0647\u062f \u0631\u0648\u06cc \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc \u0647\u0627\u06cc \u0622\u06cc\u0646\u062f\u0647<\/p>\n<p>\u0645\u0646 \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0631\u0627 \u0628\u0627 \u0627\u0646\u062a\u0642\u0627\u0644 \u0628\u0647 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc survey-spa\/config \u0648 \u0627\u0635\u0644\u0627\u062d \u0622\u0646 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u0645 <code>dev.env.js<\/code> \u0648 <code>prod.env.js<\/code> \u0641\u0627\u06cc\u0644 \u0647\u0627 \u0628\u0627 \u062a\u0639\u0631\u06cc\u0641 \u0645\u062a\u063a\u06cc\u0631\u06cc \u0628\u0647 \u0646\u0627\u0645 <code>API_URL<\/code> \u06a9\u0647 \u0628\u0647 \u0622\u0646\u0647\u0627 \u0645\u0642\u062f\u0627\u0631\u06cc \u0627\u0632 <code>http:\/\/localhost:5000\/api<\/code> \u0628\u0631\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u0647 \u0648 <code>http:\/\/${process.env.BASE_URL}\/api<\/code> \u0628\u0631\u0627\u06cc \u067e\u0631\u0648\u062f \u0645\u0637\u0627\u0628\u0642 \u0634\u06a9\u0644 \u0632\u06cc\u0631:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/ dev.env.js<\/span>\n<span class=\"hljs-meta\">\n'use strict'<\/span>\n<span class=\"hljs-keyword\">const<\/span> merge = <span class=\"hljs-built_in\">require<\/span>(<span class=\"hljs-string\">'webpack-merge'<\/span>)\n<span class=\"hljs-keyword\">const<\/span> prodEnv = <span class=\"hljs-built_in\">require<\/span>(<span class=\"hljs-string\">'.\/prod.env'<\/span>)\n\n<span class=\"hljs-built_in\">module<\/span>.exports = merge(prodEnv, {\n  <span class=\"hljs-attr\">NODE_ENV<\/span>: <span class=\"hljs-string\">'\"development\"'<\/span>,\n  <span class=\"hljs-attr\">API_URL<\/span>: <span class=\"hljs-built_in\">JSON<\/span>.stringify(<span class=\"hljs-string\">`http:\/\/localhost:5000\/api`<\/span>)\n})\n<\/code><\/pre>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/ prod.env.js<\/span>\n<span class=\"hljs-meta\">'use strict'<\/span>\n<span class=\"hljs-built_in\">module<\/span>.exports = {\n  <span class=\"hljs-attr\">NODE_ENV<\/span>: <span class=\"hljs-string\">'\"production\"'<\/span>,\n  <span class=\"hljs-attr\">API_URL<\/span>: <span class=\"hljs-built_in\">JSON<\/span>.stringify(<span class=\"hljs-string\">`http:\/\/<span class=\"hljs-subst\">${process.env.BASE_URL}<\/span>\/api`<\/span>)\n}\n<\/code><\/pre>\n<p><em>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f<\/em>: \u0627\u0631\u0632\u0634 <code>process.env.BASE_URL<\/code> \u06cc\u06a9 \u0645\u062a\u063a\u06cc\u0631 \u0645\u062d\u06cc\u0637\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u0646 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0633\u0631\u0648\u0631 \u0627\u0648\u0628\u0648\u0646\u062a\u0648 \u0627\u0636\u0627\u0641\u0647 \u062e\u0648\u0627\u0647\u0645 \u06a9\u0631\u062f <code>.bash\\_profile<\/code> \u0648 \u0622\u0646 \u0631\u0627 \u0628\u0631\u0627\u0628\u0631 \u0628\u0627 \u0622\u062f\u0631\u0633 IP \u0633\u0631\u0648\u0631 \u0642\u0631\u0627\u0631 \u062f\u0647\u06cc\u062f.<\/p>\n<p>\u0633\u067e\u0633 \u062f\u0631 <code>api\/index.js<\/code> \u0645\u0646 \u062e\u0637 \u0631\u0627 \u0627\u0635\u0644\u0627\u062d \u0645\u06cc \u06a9\u0646\u0645 <code>const API_URL = 'http:\/\/127.0.0.1:5000\/api'<\/code> \u0648 \u0622\u0646 \u0631\u0627 \u0628\u0631\u0627\u0628\u0631 \u0642\u0631\u0627\u0631 \u062f\u0647\u06cc\u062f <code>process.env.API_URL<\/code>.<\/p>\n<p>\u0628\u0639\u062f\u060c \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 Flask \u0628\u0627\u06cc\u062f \u06cc\u06a9 \u0645\u0627\u0698\u0648\u0644 \u062c\u062f\u06cc\u062f \u0628\u0647 \u0646\u0627\u0645 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u0645 <code>wsgi.py<\/code> \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0646\u0642\u0637\u0647 \u0648\u0631\u0648\u062f \u0628\u0647 Flask REST API \u062e\u062f\u0645\u062a \u06a9\u0646\u062f.  \u0627\u06cc\u0646 <code>wsgi.py<\/code> \u0645\u0627\u0698\u0648\u0644 \u06a9\u0627\u0645\u0644\u0627\u064b \u0645\u0634\u0627\u0628\u0647 \u0628\u0647 \u0646\u0638\u0631 \u0645\u06cc \u0631\u0633\u062f <code>appserver.py<\/code> \u0645\u0627\u0698\u0648\u0644 \u0628\u0647 \u062c\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u0647\u06cc\u0686 \u062a\u0645\u0627\u0633\u06cc \u0628\u0627 \u0622\u0646 \u0646\u062f\u0627\u0631\u062f <code>run(...)<\/code> \u0631\u0648\u0634 \u0634\u06cc \u0628\u0631\u0646\u0627\u0645\u0647  \u0627\u06cc\u0646 \u0628\u0647 \u0627\u06cc\u0646 \u062f\u0644\u06cc\u0644 \u0627\u0633\u062a \u06a9\u0647 \u0634\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0641\u0631\u0627\u062e\u0648\u0627\u0646 \u0628\u0631\u0627\u06cc uWSGI \u0639\u0645\u0644 \u0645\u06cc \u06a9\u0646\u062f container \u0633\u0631\u0648\u0631 \u0628\u0631\u0627\u06cc \u0627\u062c\u0631\u0627 \u062f\u0631 \u0645\u0642\u0627\u0628\u0644 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u067e\u0631\u0648\u062a\u06a9\u0644 \u0628\u0627\u06cc\u0646\u0631\u06cc \u0633\u0631\u06cc\u0639 \u062e\u0648\u062f \u0628\u0647 \u062c\u0627\u06cc \u0633\u0631\u0648\u0631 \u062a\u0648\u0633\u0639\u0647 \u0645\u0639\u0645\u0648\u0644\u06cc \u06a9\u0647 \u062f\u0631 \u0632\u0645\u0627\u0646 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u0634\u0648\u062f <code>app.run(...)<\/code> \u0646\u0627\u0645\u06cc\u062f\u0647 \u0645\u06cc\u0634\u0648\u062f.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\"># backend\/wsgi.py<\/span>\n\n<span class=\"hljs-keyword\">from<\/span> surveyapi.application <span class=\"hljs-keyword\">import<\/span> create_app\napp = create_app()\n<\/code><\/pre>\n<p>\u0628\u0627 \u062a\u0645\u0627\u0645 \u0634\u062f\u0646 \u0627\u06cc\u0646 \u06a9\u0627\u0631\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0645 \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a\u0645 \u0631\u0627 \u0628\u0647 \u06a9\u0646\u062a\u0631\u0644 \u0646\u0633\u062e\u0647 \u0641\u0634\u0627\u0631 \u062f\u0647\u0645 \u0648 \u0628\u0647 \u0633\u0631\u0648\u0631 \u062a\u0648\u0644\u06cc\u062f \u062e\u0648\u062f \u0628\u0631\u0648\u0645 \u062a\u0627 \u067e\u0631\u0648\u0698\u0647 \u0631\u0627 \u067e\u0627\u06cc\u06cc\u0646 \u0628\u06cc\u0627\u0648\u0631\u0645 \u0648 \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627\u06cc\u06cc \u0631\u0627 \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0627\u062c\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u0645 \u06a9\u0631\u062f\u060c \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u0645. \u0631\u0648\u06cc \u0633\u0631\u0648\u0631 \u062a\u0648\u0644\u06cc\u062f<\/p>\n<h2 id=\"readyingtheubuntuserver\"><span class=\"ez-toc-section\" id=\"%d8%af%d8%b1_%d8%ad%d8%a7%d9%84_%d8%a2%d9%85%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%d8%b3%d8%b1%d9%88%d8%b1_%d8%a7%d9%88%d8%a8%d9%88%d9%86%d8%aa%d9%88\"><\/span>\u062f\u0631 \u062d\u0627\u0644 \u0622\u0645\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0633\u0631\u0648\u0631 \u0627\u0648\u0628\u0648\u0646\u062a\u0648<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f \u0648\u0627\u0631\u062f \u0633\u0631\u0648\u0631 \u062e\u0635\u0648\u0635\u06cc \u0645\u062c\u0627\u0632\u06cc \u0627\u0648\u0628\u0648\u0646\u062a\u0648 \u062a\u0648\u0644\u06cc\u062f\u06cc \u062e\u0648\u062f \u0645\u06cc \u0634\u0648\u0645 \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u062a\u0648\u0633\u0637 \u06cc\u06a9\u06cc \u0627\u0632 \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u0633\u0631\u0648\u06cc\u0633 \u0647\u0627\u06cc Cloud \u0645\u0627\u0646\u0646\u062f AWS\u060c DigitalOcean\u060c Linode \u0648 \u063a\u06cc\u0631\u0647 \u0645\u06cc\u0632\u0628\u0627\u0646\u06cc \u0634\u0648\u062f \u0648 \u0634\u0631\u0648\u0639 \u0628\u0647 \u0646\u0635\u0628 \u0647\u0645\u0647 \u0686\u06cc\u0632\u0647\u0627\u06cc\u06cc \u0645\u06cc \u06a9\u0646\u0645 \u06a9\u0647 \u062f\u0631 \u0644\u06cc\u0633\u062a \u0644\u06cc\u0633\u062a \u06a9\u0631\u062f\u0645. <em>\u0645\u0631\u0648\u0631\u06cc \u0628\u0631 \u0641\u0646\u0627\u0648\u0631\u06cc \u0647\u0627<\/em> \u0628\u062e\u0634.<\/p>\n<pre><code class=\"hljs\">$ apt-get update\n$ apt-get install python3-pip python3-dev python3-venv nginx nodejs npm\n<\/code><\/pre>\n<p>\u0628\u0627 \u0627\u06cc\u0646 \u0646\u0635\u0628\u200c\u0647\u0627\u060c \u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0628\u0647 \u0646\u0627\u0645 &#8220;\u0628\u0631\u0631\u0633\u06cc&#8221; \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u0645 \u062a\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u062f\u0631 \u0632\u06cc\u0631 \u0627\u062c\u0631\u0627 \u06a9\u0631\u062f\u0647 \u0648 \u06a9\u062f \u0631\u0627 \u062f\u0631 \u062e\u0648\u062f \u062c\u0627\u06cc \u062f\u0647\u062f.<\/p>\n<pre><code class=\"hljs\">$ adduser survey\n$ usermod -aG sudo survey\n$ su survey\n$ <span class=\"hljs-built_in\">cd<\/span>\n<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0628\u0627\u06cc\u062f \u062f\u0631 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u0627\u0635\u0644\u06cc \u06a9\u0627\u0631\u0628\u0631 &#8220;survey&#8221; \u062f\u0631 \/home\/survey \u0628\u0627\u0634\u0645.<\/p>\n<p>\u0628\u0627 \u0627\u06cc\u062c\u0627\u062f \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0645\u06cc \u062a\u0648\u0627\u0646\u0645 \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0631\u0648\u0632 \u06a9\u0646\u0645 <code>.bash\\_profile<\/code> \u0641\u0627\u06cc\u0644\u06cc \u06a9\u0647 \u0628\u0627 \u0627\u0641\u0632\u0648\u062f\u0646 \u0627\u06cc\u0646 \u062e\u0637 \u0628\u0647 \u0627\u0646\u062a\u0647\u0627\u06cc \u0641\u0627\u06cc\u0644\u060c \u062d\u0627\u0648\u06cc \u0622\u062f\u0631\u0633 IP \u0633\u0631\u0648\u0631 \u062a\u0648\u0644\u06cc\u062f \u0645\u0646 \u0628\u0627\u0634\u062f.  \u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f \u06a9\u0647 123.45.67.89 \u0646\u0634\u0627\u0646 \u062f\u0647\u0646\u062f\u0647 \u06cc\u06a9 \u0622\u062f\u0631\u0633 IP \u062c\u0639\u0644\u06cc \u0633\u0631\u0648\u0631 \u0645\u0646 \u0627\u0633\u062a.  \u0627\u06af\u0631 \u062f\u0646\u0628\u0627\u0644 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u062f \u0622\u0646 \u0631\u0627 \u0628\u0627 \u0622\u062f\u0631\u0633 IP \u0648\u0627\u0642\u0639\u06cc \u062e\u0648\u062f \u062c\u0627\u06cc\u06af\u0632\u06cc\u0646 \u06a9\u0646\u06cc\u062f.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-built_in\">export<\/span> BASE_URL=123.45.67.89\n<\/code><\/pre>\n<p>\u0628\u0639\u062f \u0645\u06cc \u062e\u0648\u0627\u0647\u0645 \u0628\u0647 \u0641\u0627\u06cc\u0631\u0648\u0627\u0644 \u0628\u06af\u0648\u06cc\u0645 (<a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/wiki.ubuntu.com\/UncomplicatedFirewall\">ufw<\/a>) \u06a9\u0647 OpenSSH \u0642\u0627\u0628\u0644 \u0642\u0628\u0648\u0644 \u0627\u0633\u062a \u0648 \u0622\u0646 \u0631\u0627 \u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u062f.<\/p>\n<pre><code class=\"hljs\">$ sudo ufw allow OpenSSH\n$ sudo ufw <span class=\"hljs-built_in\">enable<\/span>\n<\/code><\/pre>\n<p>\u0628\u0627 \u0627\u0646\u062c\u0627\u0645 \u0627\u06cc\u0646 \u06a9\u0627\u0631\u060c \u0627\u06a9\u0646\u0648\u0646 \u0645\u062e\u0632\u0646 \u0631\u0627 \u0631\u0648\u06cc \u0633\u0631\u0648\u0631 \u06a9\u0644\u0648\u0646 \u0645\u06cc \u06a9\u0646\u0645 \u062a\u0627 \u0628\u062a\u0648\u0627\u0646\u0645 \u0622\u0646 \u0631\u0627 \u0628\u0633\u0627\u0632\u0645 \u0648 \u0645\u0633\u062a\u0642\u0631 \u06a9\u0646\u0645.<\/p>\n<pre><code class=\"hljs\">$ git <span class=\"hljs-built_in\">clone<\/span> https:\/\/github.com\/amcquistan\/flask-vuejs-survey.git\n<\/code><\/pre>\n<p>\u062d\u0627\u0644\u0627 \u0645\u0646 \u0633\u06cc \u062f\u06cc \u0631\u0627 \u0648\u0627\u0631\u062f \u0645\u06cc \u06a9\u0646\u0645 <code>flask-vuejs-survey\/frontend\/survey-spa<\/code> \u0648 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627\u06cc \u0641\u0631\u0627\u0646\u062a \u0627\u0646\u062f \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0633\u0627\u062e\u062a \u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u062a\u0648\u0644\u06cc\u062f\u06cc \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f.<\/p>\n<pre><code class=\"hljs\">$ <span class=\"hljs-built_in\">cd<\/span> flask-vuejs-survey\/frontend\/survey-spa\n$ npm install\n$ npm run build\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u06cc\u06a9 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u062c\u062f\u06cc\u062f \u0628\u0647 \u0646\u0627\u0645 &#8220;dist&#8221; \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u062d\u0627\u0648\u06cc \u06cc\u06a9 index.html \u0627\u0633\u062a page \u0648 \u06cc\u06a9 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u0628\u0647 \u0646\u0627\u0645 &#8220;static&#8221; \u06a9\u0647 \u0634\u0627\u0645\u0644 \u062a\u0645\u0627\u0645 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc CSS \u0648 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u06a9\u0627\u0645\u067e\u0627\u06cc\u0644 \u0634\u062f\u0647 \u0627\u0633\u062a.  \u0627\u06cc\u0646\u0647\u0627 \u0686\u06cc\u0632\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u0646 \u0633\u0631\u0648\u0631 Nginx \u0631\u0627 \u0628\u0631\u0627\u06cc \u062a\u0634\u06a9\u06cc\u0644 \u0628\u0631\u0646\u0627\u0645\u0647 \u0641\u0631\u0627\u0646\u062a \u0627\u0646\u062f SPA \u062e\u0648\u0627\u0647\u0645 \u062f\u0627\u0634\u062a.<\/p>\n<p>\u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f\u060c \u06cc\u06a9 \u0645\u062d\u06cc\u0637 \u0645\u062c\u0627\u0632\u06cc \u062f\u0631 \u0641\u0647\u0631\u0633\u062a \/home\/survey \u0628\u0631\u0627\u06cc \u06cc\u06a9 \u0645\u0641\u0633\u0631 Python3 \u0627\u06cc\u0632\u0648\u0644\u0647 \u0628\u0631\u0627\u06cc \u0627\u062c\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 Python \u0627\u06cc\u062c\u0627\u062f \u062e\u0648\u0627\u0647\u0645 \u06a9\u0631\u062f.  \u067e\u0633 \u0627\u0632 \u0646\u0635\u0628\u060c \u0622\u0646 \u0631\u0627 \u0641\u0639\u0627\u0644 \u0645\u06cc \u06a9\u0646\u0645 \u0648 \u0628\u0647 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u067e\u0631\u0648\u0698\u0647 \u0628\u0627\u0637\u0646 \u0645\u06cc \u0631\u0648\u0645 \u062a\u0627 \u0628\u0633\u062a\u0647 \u0647\u0627\u06cc \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0645\u0634\u062e\u0635 \u0634\u062f\u0647 \u062f\u0631 \u0622\u0646 \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0646\u0645. <code>requirements.txt<\/code> \u0641\u0627\u06cc\u0644.<\/p>\n<pre><code class=\"hljs\">$ python3 -m venv venv\n$ <span class=\"hljs-built_in\">source<\/span> venv\/bin\/activate\n(venv) $ <span class=\"hljs-built_in\">cd<\/span> flask-vuejs-survey\/backend\n(venv) $ pip install -r requirements.txt\n<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u0645 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 SQLite \u0631\u0627 \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u0627\u0648\u0644\u06cc\u0647 \u06a9\u0646\u0645 \u0648 \u0645\u0647\u0627\u062c\u0631\u062a \u0647\u0627 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u062c\u062f\u0627\u0648\u0644 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0645\u062e\u062a\u0644\u0641 \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 REST API \u0627\u062c\u0631\u0627 \u06a9\u0646\u0645.<\/p>\n<pre><code class=\"hljs\">(venv) $ python manage.py db upgrade\n<\/code><\/pre>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0631\u062d\u0644\u0647 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u0645 \u0633\u0631\u0648\u0631 \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u0647 Flask \u0631\u0627 \u0631\u0648\u0634\u0646 \u06a9\u0646\u0645 \u062a\u0627 \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u0645 \u06a9\u0647 \u0647\u0645\u0647 \u0686\u06cc\u0632 \u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 \u0627\u0646\u062a\u0638\u0627\u0631 \u0645\u06cc\u200c\u0631\u0648\u062f \u06a9\u0627\u0631 \u0645\u06cc\u200c\u06a9\u0646\u062f.  \u0642\u0628\u0644 \u0627\u0632 \u0627\u0646\u062c\u0627\u0645 \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0628\u0627\u06cc\u062f \u0628\u0647 \u0622\u0646 \u0628\u06af\u0648\u06cc\u0645 <code>ufw<\/code> \u0633\u0631\u0648\u06cc\u0633\u06cc \u0628\u0631\u0627\u06cc \u0627\u062c\u0627\u0632\u0647 \u062a\u0631\u062f\u062f \u0628\u0647 \u062f\u0627\u062e\u0644 \u0631\u0648\u06cc \u067e\u0648\u0631\u062a 5000.<\/p>\n<pre><code class=\"hljs\">(venv) $ sudo ufw allow 5000\n(venv) $ python appserver.py\n<\/code><\/pre>\n<p>\u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631\u06cc \u06a9\u0647 \u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u0645 \u0628\u0647 \u0622\u0646 \u0628\u0631\u0648\u0645 <code>http:\/\/123.45.67.89:5000\/api\/surveys\/<\/code> \u0648 \u0645\u0646 \u0628\u0627\u06cc\u062f \u06cc\u06a9 \u067e\u0627\u0633\u062e JSON \u0633\u0627\u062f\u0647 \u0631\u0627 \u0628\u0628\u06cc\u0646\u0645 <code>()<\/code> \u0632\u06cc\u0631\u0627 \u0647\u0646\u0648\u0632 \u0647\u06cc\u0686 \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u062f\u0631 \u0627\u06cc\u0646 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0648\u062c\u0648\u062f \u0646\u062f\u0627\u0631\u062f\u060c \u0627\u0645\u0627 \u0627\u06cc\u0646 \u0646\u0634\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u06a9\u0647 \u06cc\u06a9 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0645\u0648\u0641\u0642\u06cc\u062a \u0622\u0645\u06cc\u0632 \u0627\u0646\u062c\u0627\u0645 \u0634\u062f\u0647 \u0627\u0633\u062a.  \u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u0627\u06cc\u0646\u060c \u062f\u0631 terminal \u0645\u062a\u0635\u0644 \u0628\u0647 \u0633\u0631\u0648\u0631 \u0628\u0627\u06cc\u062f \u06cc\u06a9 \u067e\u06cc\u0627\u0645 \u0648\u0627\u0631\u062f \u0634\u062f\u0647 \u0628\u0631\u0627\u06cc \u0622\u0646 \u0648\u062c\u0648\u062f \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f <em>\u06af\u0631\u0641\u062a\u0646<\/em> \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0627\u0632 \u0645\u0631\u0648\u0631\u06af\u0631 \u0645\u0646 \u0635\u0627\u062f\u0631 \u0634\u062f.<\/p>\n<p>Ctrl+C \u0631\u0627 \u062f\u0631 \u0642\u0633\u0645\u062a \u06a9\u0644\u06cc\u062f \u0645\u06cc \u0632\u0646\u0645 terminal \u0628\u0631\u0627\u06cc \u06a9\u0634\u062a\u0646 \u0633\u0631\u0648\u0631 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u0647 Flask \u0648 \u062d\u0631\u06a9\u062a \u0631\u0648\u06cc \u0628\u0631\u0627\u06cc \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc uWSGI \u0628\u0631\u0627\u06cc \u06a9\u0646\u062a\u0631\u0644 \u0627\u062c\u0631\u0627\u06cc Flask REST API \u0645\u0646.  \u0627\u06af\u0631 \u062a\u0639\u062c\u0628 \u0645\u06cc \u06a9\u0646\u06cc\u062f \u06a9\u0647 uWSGI \u0627\u0632 \u06a9\u062c\u0627 \u0622\u0645\u062f\u0647 \u0627\u0633\u062a\u060c \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0627\u0644\u0632\u0627\u0645 \u062f\u0631 \u0622\u0646 \u0645\u0634\u062e\u0635 \u0634\u062f\u0647 \u0627\u0633\u062a <code>requirements.txt<\/code> \u0641\u0627\u06cc\u0644\u06cc \u06a9\u0647 \u0645\u0646 pip \u0646\u0635\u0628 \u0634\u062f\u0647 \u0628\u0627 \u0642\u0628\u0644<\/p>\n<h2 id=\"settingupuwsgicontainerserver\"><span class=\"ez-toc-section\" id=\"%d8%b1%d8%a7%d9%87_%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c_uwsgi_container_%d8%b3%d8%b1%d9%88%d8%b1\"><\/span>\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc uWSGI Container \u0633\u0631\u0648\u0631<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0645\u0634\u0627\u0628\u0647 \u06a9\u0627\u0631\u06cc \u06a9\u0647 \u0628\u0627 \u0633\u0631\u0648\u0631 \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u0647 Flask \u0627\u0646\u062c\u0627\u0645 \u062f\u0627\u062f\u0645\u060c \u0627\u06a9\u0646\u0648\u0646 \u0622\u0632\u0645\u0627\u06cc\u0634 \u0645\u06cc\u200c\u06a9\u0646\u0645 \u06a9\u0647 \u0633\u0631\u0648\u0631 uWSGI \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u0628\u0647 \u0635\u0648\u0631\u062a \u0632\u06cc\u0631 \u0627\u0631\u0627\u0626\u0647 \u062f\u0647\u062f.<\/p>\n<pre><code class=\"hljs\">(venv) $ uwsgi --socket 0.0.0.0:5000 --protocol=http -w wsgi:app\n<\/code><\/pre>\n<p>\u0645\u062c\u062f\u062f\u0627\u064b\u060c \u0628\u0627 \u0631\u0641\u062a\u0646 \u0628\u0647 \u0645\u0631\u0648\u0631\u06af\u0631 \u062e\u0648\u062f \u0648 \u0628\u0627\u0632\u062e\u0648\u0627\u0646\u06cc \u0647\u0645\u0627\u0646 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u06cc \u06a9\u0647 \u0642\u0628\u0644\u0627\u064b \u062f\u0627\u062f\u0647 \u0628\u0648\u062f\u0645\u060c \u0628\u0627\u06cc\u062f \u06cc\u06a9 \u067e\u0627\u0633\u062e \u0622\u0631\u0627\u06cc\u0647 JSON \u062e\u0627\u0644\u06cc \u0631\u0627 \u0628\u0631\u06af\u0631\u062f\u0627\u0646\u06cc\u062f.  \u0648\u0642\u062a\u06cc \u0627\u0632 \u067e\u06cc\u0634\u0631\u0641\u062a\u0645 \u0631\u0627\u0636\u06cc \u0634\u062f\u0645\u060c \u062f\u0648\u0628\u0627\u0631\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0645 Ctrl+C \u0631\u0627 \u062f\u0631 \u0622\u0646 \u06a9\u0644\u06cc\u062f \u0628\u0632\u0646\u0645 terminal \u0648 \u062d\u0631\u06a9\u062a \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc.<\/p>\n<p>\u062f\u0648 \u0645\u0631\u062d\u0644\u0647 \u062f\u06cc\u06af\u0631 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0645\u06cc \u062e\u0648\u0627\u0647\u0645 \u0628\u0631\u0627\u06cc \u062a\u06a9\u0645\u06cc\u0644 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc uWSGI \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u0645 container \u0633\u0631\u0648\u0631  \u06cc\u06a9 \u0645\u0631\u062d\u0644\u0647 \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u06a9\u0647 uWSGI \u0622\u0646 \u0631\u0627 \u0628\u062e\u0648\u0627\u0646\u062f \u0648 \u062f\u0631 \u0622\u0646 \u062c\u0627\u06cc\u06af\u0632\u06cc\u0646 \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u067e\u0631\u0686\u0645\u200c\u0647\u0627 \u0648 \u0622\u0631\u06af\u0648\u0645\u0627\u0646\u200c\u0647\u0627\u06cc \u062e\u0637 \u0641\u0631\u0645\u0627\u0646 \u0634\u0648\u062f \u06a9\u0647 \u062f\u0631 \u0628\u0627\u0644\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f\u0645.  \u0645\u0631\u062d\u0644\u0647 \u062f\u0648\u0645 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 <code>systemd<\/code> \u0641\u0627\u06cc\u0644 \u0633\u0631\u0648\u06cc\u0633 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a uWSGI container \u0633\u0631\u0648\u0631 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0633\u0631\u0648\u06cc\u0633 \u0645\u0627\u0646\u0646\u062f \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u0633\u0631\u0648\u06cc\u0633 \u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u06a9\u0647 \u0642\u0628\u0644\u0627\u064b \u062f\u0631 \u062d\u0627\u0644 \u0627\u062c\u0631\u0627 \u0647\u0633\u062a\u0646\u062f \u0631\u0648\u06cc \u0633\u0631\u0648\u0631 \u0627\u0648\u0628\u0648\u0646\u062a\u0648<\/p>\n<p>\u062f\u0631 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc backend \u0641\u0627\u06cc\u0644\u06cc \u0628\u0647 \u0646\u0627\u0645 \u0645\u06cc \u0633\u0627\u0632\u0645 <code>surveyapi.ini<\/code> \u0648 \u0622\u0646 \u0631\u0627 \u0628\u0627 \u0645\u0648\u0627\u0631\u062f \u0632\u06cc\u0631 \u067e\u0631 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-section\">(uwsgi)<\/span>\n<span class=\"hljs-attr\">module<\/span> = wsgi:app\n\n<span class=\"hljs-attr\">master<\/span> = <span class=\"hljs-literal\">true<\/span>\n<span class=\"hljs-attr\">processes<\/span> = <span class=\"hljs-number\">4<\/span>\n\n<span class=\"hljs-attr\">socket<\/span> = myproject.sock\n<span class=\"hljs-attr\">chmod-socket<\/span> = <span class=\"hljs-number\">660<\/span>\n<span class=\"hljs-attr\">vacuum<\/span> = <span class=\"hljs-literal\">true<\/span>\n\n<span class=\"hljs-attr\">die-\u0631\u0648\u06cc-term<\/span> = <span class=\"hljs-literal\">true<\/span>\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u0641\u0627\u06cc\u0644 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0628\u0647 uWSGI \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc\u200c\u062f\u0647\u062f \u0628\u062f\u0627\u0646\u062f \u06a9\u0647 \u0642\u0627\u0628\u0644 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc\u060c \u0634\u06cc\u0621 \u0628\u0631\u0646\u0627\u0645\u0647 \u062f\u0627\u062e\u0644 \u0622\u0646 \u0627\u0633\u062a <code>wsgi.py<\/code> \u0645\u062f\u0648\u0644.  \u0647\u0645\u0686\u0646\u06cc\u0646 \u0628\u0647 \u0622\u0646 \u0645\u06cc\u200c\u06af\u0648\u06cc\u062f \u06a9\u0647 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u062f \u0648 \u0627\u0632 \u0686\u0647\u0627\u0631 \u0641\u0631\u0622\u06cc\u0646\u062f \u0628\u0631\u0627\u06cc \u0631\u0633\u06cc\u062f\u06af\u06cc \u0628\u0647 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0627\u06cc \u06a9\u0647 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u0633\u0648\u06a9\u062a \u0628\u0647 \u0646\u0627\u0645 \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc\u200c\u0634\u0648\u0646\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u062f. <code>surveyapi.sock<\/code> \u06a9\u0647 \u062f\u0627\u0631\u0627\u06cc \u0645\u062c\u0648\u0632 \u06a9\u0627\u0641\u06cc \u0628\u0631\u0627\u06cc \u062e\u0648\u0627\u0646\u062f\u0646 \u0648 \u0646\u0648\u0634\u062a\u0646 \u0648\u0628 \u0633\u0631\u0648\u0631 Nginx \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a.  \u0627\u06cc\u0646 <code>vacuum<\/code> \u0648 <code>die-\u0631\u0648\u06cc-term<\/code> \u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u0628\u0631\u0627\u06cc \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0627\u0632 \u067e\u0627\u06a9\u0633\u0627\u0632\u06cc \u0645\u0646\u0627\u0633\u0628 \u0627\u0633\u062a.<\/p>\n<p>\u0628\u0631\u0627\u06cc <code>systemd<\/code> \u0641\u0627\u06cc\u0644 \u0633\u0631\u0648\u06cc\u0633\u060c \u0628\u0627\u06cc\u062f \u0641\u0627\u06cc\u0644\u06cc \u0628\u0647 \u0646\u0627\u0645 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u0645 <code>surveyapi.service<\/code> \u062f\u0631 <code>\/etc\/systemd\/system<\/code> \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u0648 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 \u0686\u0646\u062f \u062a\u0648\u0635\u06cc\u0641\u06af\u0631 \u0628\u0647 \u0627\u0636\u0627\u0641\u0647 \u062f\u0633\u062a\u0648\u0631\u0627\u062a \u062f\u0633\u062a\u0631\u0633\u06cc\u060c \u0646\u0648\u0634\u062a\u0646 \u0648 \u0627\u062c\u0631\u0627 \u0645\u0627\u0646\u0646\u062f:<\/p>\n<pre><code class=\"hljs\">(venv) $ sudo nano \/etc\/systemd\/system\/surveyapi.service\n<\/code><\/pre>\n<p>\u0633\u067e\u0633 \u0622\u0646 \u0631\u0627 \u0628\u0627 \u0645\u0648\u0627\u0631\u062f \u0632\u06cc\u0631 \u067e\u0631 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-section\">(Unit)<\/span>\n<span class=\"hljs-attr\">Description<\/span>=uWSGI Python container server\n<span class=\"hljs-attr\">After<\/span>=network.target\n\n<span class=\"hljs-section\">(Service)<\/span>\n<span class=\"hljs-attr\">User<\/span>=survey\n<span class=\"hljs-attr\">Group<\/span>=www-data\n<span class=\"hljs-attr\">WorkingDirectory<\/span>=\/home\/survey\/flask-vuejs-survey\/backend\n<span class=\"hljs-attr\">Environment<\/span>=<span class=\"hljs-string\">\"PATH=\/home\/survey\/venv\/bin\"<\/span>\n<span class=\"hljs-attr\">ExecStart<\/span>=\/home\/survey\/venv\/bin\/uwsgi --ini surveyapi.ini\n\n<span class=\"hljs-section\">(Install)<\/span>\n<span class=\"hljs-attr\">WantedBy<\/span>=multi-user.target\n<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0645 \u0633\u0631\u0648\u06cc\u0633 \u0631\u0627 \u0631\u0627\u0647\u200c\u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0646\u0645 \u0648 \u0648\u0636\u0639\u06cc\u062a \u0622\u0646 \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u0645 \u0648 \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u0645 \u06a9\u0647 \u0641\u0647\u0631\u0633\u062a \u0628\u0627\u0637\u0646 \u0627\u06a9\u0646\u0648\u0646 \u062d\u0627\u0648\u06cc \u0627\u0633\u062a <code>surveyapi.sock<\/code>.<\/p>\n<pre><code class=\"hljs\">(venv) $ sudo systemctl start surveyapi\n(venv) $ sudo systemctl status surveyapi\n   Loaded: loaded (\/etc\/systemd\/system\/surveyapi.service; disabled; vendor preset: enabled)\n   Active: active (running) since Mon 2018-04-23 19:23:01 UTC; 2min 28s ago\n Main PID: 11221 (uwsgi)\n    Tasks: 6\n   Memory: 28.1M\n      CPU: 384ms\n   CGroup: \/system.slice\/surveyapi.service\n           \u251c\u250011221 \/home\/survey\/venv\/bin\/uwsgi --ini surveyapi.ini\n           \u251c\u250011226 \/home\/survey\/venv\/bin\/uwsgi --ini surveyapi.ini\n           \u251c\u250011227 \/home\/survey\/venv\/bin\/uwsgi --ini surveyapi.ini\n           \u251c\u250011228 \/home\/survey\/venv\/bin\/uwsgi --ini surveyapi.ini\n           \u251c\u250011229 \/home\/survey\/venv\/bin\/uwsgi --ini surveyapi.ini\n           \u2514\u250011230 \/home\/survey\/venv\/bin\/uwsgi --ini surveyapi.ini\n\nApr 23 19:23:01 ubuntu-s-1vcpu-2gb-sfo2-01 uwsgi(11221): mapped 437520 bytes (427 KB) <span class=\"hljs-keyword\">for<\/span> 5 cores\nApr 23 19:23:01 ubuntu-s-1vcpu-2gb-sfo2-01 uwsgi(11221): *** Operational MODE: preforking ***\nApr 23 19:23:01 ubuntu-s-1vcpu-2gb-sfo2-01 uwsgi(11221): WSGI app 0 (mountpoint=<span class=\"hljs-string\">''<\/span>) ready <span class=\"hljs-keyword\">in<\/span> 0 seconds \u0631\u0648\u06cc interpreter 0x8b4c30 pid: 112\nApr 23 19:23:01 ubuntu-s-1vcpu-2gb-sfo2-01 uwsgi(11221): *** uWSGI is running <span class=\"hljs-keyword\">in<\/span> multiple interpreter mode ***\nApr 23 19:23:01 ubuntu-s-1vcpu-2gb-sfo2-01 uwsgi(11221): spawned uWSGI master process (pid: 11221)\nApr 23 19:23:01 ubuntu-s-1vcpu-2gb-sfo2-01 uwsgi(11221): spawned uWSGI worker 1 (pid: 11226, cores: 1)\nApr 23 19:23:01 ubuntu-s-1vcpu-2gb-sfo2-01 uwsgi(11221): spawned uWSGI worker 2 (pid: 11227, cores: 1)\nApr 23 19:23:01 ubuntu-s-1vcpu-2gb-sfo2-01 uwsgi(11221): spawned uWSGI worker 3 (pid: 11228, cores: 1)\nlines 1-23\n(venv) $ ls -l \/home\/survey\/flask-vuejs-survey\/backend\n-rw-rw-r-- 1 survey survey     201 Apr 23 18:18 appserver.py\n-rw-rw-r-- 1 survey survey     745 Apr 23 17:55 manage.py\ndrwxrwxr-x 4 survey survey    4096 Apr 23 18:06 migrations\ndrwxrwxr-x 2 survey survey    4096 Apr 23 18:52 __pycache__\n-rw-rw-r-- 1 survey survey     397 Apr 23 18:46 requirements.txt\ndrwxrwxr-x 3 survey survey    4096 Apr 23 18:06 surveyapi\n-rw-rw-r-- 1 survey survey     133 Apr 23 19:04 surveyapi.ini\nsrw-rw---- 1 survey www-data     0 Apr 23 19:23 surveyapi.sock\n-rw-r--r-- 1 survey survey   10240 Apr 23 18:19 survey.db\n-rw-rw-r-- 1 survey survey      84 Apr 23 18:42 wsgi.py\n<\/code><\/pre>\n<p>\u0639\u0627\u0644\u06cc!  \u0622\u062e\u0631\u06cc\u0646 \u06a9\u0627\u0631\u06cc \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u0645 \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0647\u0631 \u0628\u0627\u0631 \u06a9\u0647 \u0633\u06cc\u0633\u062a\u0645 \u0628\u0648\u062a \u0645\u06cc \u0634\u0648\u062f\u060c \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u062e\u0648\u062f\u06a9\u0627\u0631 \u0631\u0627 \u0641\u0639\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u062d\u0627\u0635\u0644 \u0634\u0648\u062f \u06a9\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0645\u06cc\u0634\u0647 \u0641\u0639\u0627\u0644 \u0627\u0633\u062a.<\/p>\n<pre><code class=\"hljs\">(venv) $ sudo systemctl <span class=\"hljs-built_in\">enable<\/span> surveyapi\n<\/code><\/pre>\n<h2 id=\"settingupnginx\"><span class=\"ez-toc-section\" id=\"%d8%b1%d8%a7%d9%87_%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c_nginx\"><\/span>\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc Nginx<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0645\u0646 \u0627\u0632 Nginx \u0628\u0631\u0627\u06cc \u0627\u0631\u0627\u0626\u0647 \u0645\u062d\u062a\u0648\u0627\u06cc \u062b\u0627\u0628\u062a \u0645\u0627\u0646\u0646\u062f HTML\u060c CSS \u0648 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0628\u0631\u0627\u06cc \u0645\u0639\u06a9\u0648\u0633 \u06a9\u0631\u062f\u0646 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc\u200c\u0647\u0627\u06cc API REST \u067e\u0631\u0648\u06a9\u0633\u06cc \u0628\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 Flask \/ uWSGI \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u0645 \u06a9\u0631\u062f.  \u0628\u0631\u0627\u06cc \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc nginx \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0627\u06cc\u0646 \u0645\u0648\u0627\u0631\u062f\u060c \u0628\u0627\u06cc\u062f \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u0645 \u06a9\u0647 \u0631\u0648\u0634 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0627\u06cc\u0646 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641 \u0631\u0627 \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0646\u062f.<\/p>\n<p>\u062f\u0631 \/etc\/nginx\/sites-available \u0641\u0627\u06cc\u0644\u06cc \u0628\u0647 \u0646\u0627\u0645 \u0628\u0631\u0631\u0633\u06cc \u0627\u06cc\u062c\u0627\u062f \u062e\u0648\u0627\u0647\u0645 \u06a9\u0631\u062f \u06a9\u0647 \u062d\u0627\u0648\u06cc \u0645\u0648\u0627\u0631\u062f \u0632\u06cc\u0631 \u0627\u0633\u062a:<\/p>\n<pre><code class=\"hljs\">server {\n    listen 80;\n    server_name 123.45.67.89;\n\n    location \/api {\n        include uwsgi_params;\n        uwsgi_pass unix:\/home\/survey\/flask-vuejs-survey\/backend\/surveyapi.sock;\n    }\n\n  location \/ {\n    root \/home\/survey\/flask-vuejs-survey\/frontend\/survey-spa\/dist;\n    try_files <span class=\"hljs-variable\">$uri<\/span> <span class=\"hljs-variable\">$uri<\/span>\/ \/index.html;\n  }\n}\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u0641\u0627\u06cc\u0644 \u06cc\u06a9 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0628\u0644\u0648\u06a9 \u0633\u0631\u0648\u0631 \u062c\u062f\u06cc\u062f \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0645\u06cc \u06af\u0648\u06cc\u062f \u0628\u0647 \u0622\u062f\u0631\u0633 IP 123.45.67.89 \u06af\u0648\u0634 \u062f\u0647\u06cc\u062f. \u0631\u0648\u06cc \u067e\u0648\u0631\u062a \u0627\u0633\u062a\u0627\u0646\u062f\u0627\u0631\u062f HTTP 80. \u0633\u067e\u0633 \u0645\u06cc\u200c\u06af\u0648\u06cc\u062f \u0628\u0647 \u062f\u0646\u0628\u0627\u0644 \u0647\u0631 \u0645\u0633\u06cc\u0631 URI \u0628\u0627\u0634\u06cc\u062f \u06a9\u0647 \u0628\u0627 \u0622\u0646 \u0634\u0631\u0648\u0639 \u0645\u06cc\u200c\u0634\u0648\u062f <code>\/api<\/code> \u0648 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0641\u0627\u06cc\u0644 \u0633\u0648\u06a9\u062a \u062a\u0639\u0631\u06cc\u0641 \u0634\u062f\u0647 \u0642\u0628\u0644\u06cc\u060c \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0633\u0631\u0648\u0631 Flask \/ uWSGI REST API \u0645\u0639\u06a9\u0648\u0633 \u06a9\u0646\u06cc\u062f.  \u062f\u0631 \u0646\u0647\u0627\u06cc\u062a\u060c \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0645\u06cc\u200c\u06af\u0648\u06cc\u062f \u06a9\u0647 \u0647\u0645\u0647 \u0686\u06cc\u0632\u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u0631\u0627 \u062f\u0631 \u0632\u06cc\u0631 \/ \u062c\u0645\u0639\u200c\u0622\u0648\u0631\u06cc \u06a9\u0646\u06cc\u062f \u0648 \u0641\u0627\u06cc\u0644 index.html \u0631\u0627 \u062f\u0631 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc dist \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 Vue.js front-end SPA \u0631\u0627 \u0642\u0628\u0644\u0627\u064b \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0645.<\/p>\n<p>\u0628\u0627 \u0627\u06cc\u062c\u0627\u062f \u0627\u06cc\u0646 \u0641\u0627\u06cc\u0644 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc\u060c \u0628\u0627\u06cc\u062f \u0628\u0627 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u067e\u06cc\u0648\u0646\u062f \u0646\u0645\u0627\u062f\u06cc\u0646 \u0628\u0647 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u0641\u0639\u0627\u0644 \/etc\/nginx\/sites\u060c \u0628\u0647 Nginx \u0627\u0637\u0644\u0627\u0639 \u062f\u0647\u0645 \u06a9\u0647 \u06cc\u06a9 \u0633\u0627\u06cc\u062a \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \u0627\u0633\u062a\u060c \u0645\u0627\u0646\u0646\u062f \u0627\u06cc\u0646:<\/p>\n<pre><code class=\"hljs\">$ sudo ln -s \/etc\/nginx\/sites-available\/survey \/etc\/nginx\/sites-enabled \n<\/code><\/pre>\n<p>\u0628\u0631\u0627\u06cc \u0627\u062c\u0627\u0632\u0647 \u062f\u0627\u062f\u0646 \u0628\u0647 \u062a\u0631\u0627\u0641\u06cc\u06a9 \u0631\u0648\u06cc \u067e\u0648\u0631\u062a HTTP \u0648 \u0627\u062a\u0635\u0627\u0644 \u0628\u0647 Nginx\u060c \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u0632\u06cc\u0631 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0622\u0646 \u0635\u0627\u062f\u0631 \u0645\u06cc\u200c\u06a9\u0646\u0645 <code>ufw<\/code> \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u067e\u0648\u0631\u062a 5000 \u0631\u0627 \u06a9\u0647 \u0642\u0628\u0644\u0627\u064b \u0628\u0627\u0632 \u0634\u062f\u0647 \u0627\u0633\u062a \u0628\u0628\u0646\u062f\u06cc\u062f.<\/p>\n<pre><code class=\"hljs\">$ sudo ufw delete allow 5000\n$ sudo ufw allow <span class=\"hljs-string\">'Nginx Full'<\/span>\n<\/code><\/pre>\n<p>\u0628\u0647 \u062f\u0646\u0628\u0627\u0644 \u0627\u06cc\u0646 \u062f\u0633\u062a\u0648\u0631\u060c \u0628\u0627\u06cc\u062f \u0633\u0631\u0648\u06cc\u0633 Nginx \u0631\u0627 \u0645\u062c\u062f\u062f\u0627\u064b \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0646\u0645 \u062a\u0627 \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc \u0647\u0627 \u0627\u0639\u0645\u0627\u0644 \u0634\u0648\u0646\u062f.<\/p>\n<pre><code class=\"hljs\">$ sudo systemctl restart nginx\n<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u0645 \u062f\u0648\u0628\u0627\u0631\u0647 \u0628\u0647 \u0645\u0631\u0648\u0631\u06af\u0631\u0645 \u0628\u0631\u0648\u0645 \u0648 \u0628\u0627\u0632\u062f\u06cc\u062f \u06a9\u0646\u0645 <code>http:\/\/123.454.67.89<\/code> \u0648 \u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u06a9\u0647 \u062f\u0631 \u0645\u0642\u0627\u0644\u0627\u062a \u0642\u0628\u0644\u06cc \u0646\u0634\u0627\u0646 \u062f\u0627\u062f\u0647 \u0627\u0645 \u0628\u0647 \u0645\u0646 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<h2 id=\"conclusion\"><span class=\"ez-toc-section\" id=\"%d9%86%d8%aa%db%8c%d8%ac%d9%87\"><\/span>\u0646\u062a\u06cc\u062c\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062e\u0648\u0628 \u0627\u06cc\u0646 \u067e\u0633\u062a \u067e\u0627\u06cc\u0627\u0646\u06cc \u0627\u06cc\u0646 \u0645\u062c\u0645\u0648\u0639\u0647 \u0622\u0645\u0648\u0632\u0634\u06cc \u0686\u0646\u062f \u0642\u0633\u0645\u062a\u06cc \u0627\u0633\u062a \u0631\u0648\u06cc \u0631\u0648\u0634 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Flask \u0648 Vue.js \u0628\u0631\u0627\u06cc \u0633\u0627\u062e\u062a\u0646 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 SPA \u0628\u0627 \u0642\u0627\u0628\u0644\u06cc\u062a REST API.  \u0645\u0646 \u0633\u0639\u06cc \u06a9\u0631\u062f\u0647\u200c\u0627\u0645 \u0628\u06cc\u0634\u062a\u0631 \u0645\u0648\u0636\u0648\u0639\u0627\u062a \u0645\u0647\u0645\u06cc \u0631\u0627 \u06a9\u0647 \u062f\u0631 \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u0645\u0648\u0627\u0631\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627\u06cc \u0648\u0628 \u0645\u0634\u062a\u0631\u06a9 \u0647\u0633\u062a\u0646\u062f\u060c \u0628\u0627 \u0641\u0631\u0636 \u062f\u0627\u0646\u0634 \u0642\u0628\u0644\u06cc \u0628\u0633\u06cc\u0627\u0631 \u06a9\u0645\u06cc \u0627\u0632 \u0641\u0646\u0627\u0648\u0631\u06cc\u200c\u0647\u0627\u06cc Flask \u0648 Vue.js \u0645\u0648\u0631\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647\u060c \u067e\u0648\u0634\u0634 \u062f\u0647\u0645.<\/p>\n<p>\u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u0627\u06cc\u0646 \u0633\u0631\u06cc\u0627\u0644 \u0631\u0627 \u062f\u0646\u0628\u0627\u0644 \u06a9\u0631\u062f\u06cc\u062f \u0645\u0645\u0646\u0648\u0646\u0645 \u0648 \u0644\u0637\u0641\u0627 \u0627\u0632 \u0646\u0638\u0631 \u062f\u0627\u062f\u0646 \u06cc\u0627 \u0646\u0642\u062f \u062f\u0631 \u0632\u06cc\u0631 \u062e\u062c\u0627\u0644\u062a \u0646\u06a9\u0634\u06cc\u062f.<\/p>\n<\/div>\n<p>    (\u0628\u0631\u0686\u0633\u0628\u200c\u0647\u0627 \u0628\u0647 \u062a\u0631\u062c\u0645\u0647)# python<br \/>\n<br \/><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-01-26 17:30:08<br \/>\n<\/p>\n\n\n<div class=\"kk-star-ratings kksr-auto kksr-align-center kksr-valign-bottom\"\n    data-payload='{&quot;align&quot;:&quot;center&quot;,&quot;id&quot;:&quot;16542&quot;,&quot;slug&quot;:&quot;default&quot;,&quot;valign&quot;:&quot;bottom&quot;,&quot;ignore&quot;:&quot;&quot;,&quot;reference&quot;:&quot;auto&quot;,&quot;class&quot;:&quot;&quot;,&quot;count&quot;:&quot;0&quot;,&quot;legendonly&quot;:&quot;&quot;,&quot;readonly&quot;:&quot;&quot;,&quot;score&quot;:&quot;0&quot;,&quot;starsonly&quot;:&quot;&quot;,&quot;best&quot;:&quot;5&quot;,&quot;gap&quot;:&quot;5&quot;,&quot;greet&quot;:&quot;\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628&quot;,&quot;legend&quot;:&quot;0\\\/5 (0 \u0631\u0627\u06cc)&quot;,&quot;size&quot;:&quot;30&quot;,&quot;title&quot;:&quot;\u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u062a\u06a9 \u0635\u0641\u062d\u0647 \u0627\u06cc \u0628\u0627 Vue.js \u0648 Flask: Deployment \u0628\u0647 \u0642\u0633\u0645\u062a \u0647\u0641\u062a\u0645 \u0648 \u0622\u062e\u0631 \u0627\u06cc\u0646 \u0645\u062c\u0645\u0648\u0639\u0647 \u0622\u0645\u0648\u0632\u0634\u06cc \u0686\u0646\u062f \u0642\u0633\u0645\u062a\u06cc \u062e\u0648\u0634 \u0622\u0645\u062f\u06cc\u062f \u0631\u0648\u06cc \u062a\u0648\u0633\u0639\u0647 \u0648\u0628 \u062a\u0645\u0627\u0645 \u067e\u0634\u062a\u0647 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Vue.js \u0648 Flask.  \u062f\u0631 \u0627\u06cc\u0646 \u067e\u0633\u062a \u0631\u0648\u0634 \u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u0633\u0627\u062e\u062a\u0647 \u0634\u062f\u0647 \u062f\u0631 \u0627\u06cc\u0646 \u0633\u0631\u06cc \u0631\u0627 \u0646\u0634\u0627\u0646 \u062e\u0648\u0627\u0647\u0645 \u062f\u0627\u062f.  \u06a9\u062f \u0627\u06cc\u0646 \u067e\u0633\u062a \u0631\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u067e\u06cc\u062f\u0627 \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc \u062d\u0633\u0627\u0628 GitHub \u0645\u0646 \u062a\u062d\u062a ...&quot;,&quot;width&quot;:&quot;0&quot;,&quot;_legend&quot;:&quot;{score}\\\/{best} ({count} \u0631\u0627\u06cc)&quot;,&quot;font_factor&quot;:&quot;1.25&quot;}'>\n            \n<div class=\"kksr-stars\">\n    \n<div class=\"kksr-stars-inactive\">\n            <div class=\"kksr-star\" data-star=\"1\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"2\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"3\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"4\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"5\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n    \n<div class=\"kksr-stars-active\" style=\"width: 0px;\">\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n<\/div>\n                \n\n<div class=\"kksr-legend\" style=\"font-size: 24px;\">\n            <span class=\"kksr-muted\">\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628<\/span>\n    <\/div>\n    <\/div>\n","protected":false},"excerpt":{"rendered":"<p><span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 8<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u062f\u0631 \u06cc\u06a9 \u0633\u0631\u0648\u0631 \u062e\u0635\u0648\u0635\u06cc \u0645\u062c\u0627\u0632\u06cc \u0628\u0647 \u0642\u0633\u0645\u062a \u0647\u0641\u062a\u0645 \u0648 \u0622\u062e\u0631 \u0627\u06cc\u0646 \u0645\u062c\u0645\u0648\u0639\u0647 \u0622\u0645\u0648\u0632\u0634\u06cc \u0686\u0646\u062f \u0642\u0633\u0645\u062a\u06cc \u062e\u0648\u0634 \u0622\u0645\u062f\u06cc\u062f \u0631\u0648\u06cc \u062a\u0648\u0633\u0639\u0647 \u0648\u0628 \u062a\u0645\u0627\u0645 \u067e\u0634\u062a\u0647 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Vue.js \u0648 Flask. \u062f\u0631 \u0627\u06cc\u0646 \u067e\u0633\u062a \u0631\u0648\u0634 \u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u0633\u0627\u062e\u062a\u0647 \u0634\u062f\u0647 \u062f\u0631 \u0627\u06cc\u0646 \u0633\u0631\u06cc \u0631\u0627 \u0646\u0634\u0627\u0646 \u062e\u0648\u0627\u0647\u0645 \u062f\u0627\u062f. \u06a9\u062f \u0627\u06cc\u0646 \u067e\u0633\u062a \u0631\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u067e\u06cc\u062f\u0627 \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc \u062d\u0633\u0627\u0628 GitHub [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":16543,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1772,620],"tags":[],"class_list":["post-16542","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-javascript","category-programming"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/16542","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/users\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/comments?post=16542"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/16542\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/16543"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=16542"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=16542"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=16542"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}