{"id":15638,"date":"2024-06-04T15:39:46","date_gmt":"2024-06-04T12:09:46","guid":{"rendered":"https:\/\/www.itpiran.net\/blog\/?p=15638"},"modified":"2024-06-04T15:39:46","modified_gmt":"2024-06-04T12:09:46","slug":"deploying-a-next-js-application-on-a-digitalocean-droplet","status":"publish","type":"post","link":"https:\/\/www.itpiran.net\/blog\/ar\/tutorials\/deploying-a-next-js-application-on-a-digitalocean-droplet\/","title":{"rendered":"\u0646\u0634\u0631 \u062a\u0637\u0628\u064a\u0642 Next.js \u0639\u0644\u0649 DigitalOcean Droplet"},"content":{"rendered":"<h2 id=\"%d9%85%d9%82%d8%af%d9%85%d9%87\">\u0645\u0642\u062f\u0645\u0629<\/h2>\n<p>Next.js \u0647\u0648 \u0625\u0637\u0627\u0631 \u0639\u0645\u0644 React \u0634\u0627\u0626\u0639 \u0627\u0644\u0627\u0633\u062a\u062e\u062f\u0627\u0645 \u0644\u0625\u0646\u0634\u0627\u0621 \u062a\u0637\u0628\u064a\u0642\u0627\u062a React \u0645\u064f\u0642\u062f\u0651\u0645\u0629 \u0645\u0646 \u0627\u0644\u062e\u0627\u062f\u0645 \u0628\u0633\u0647\u0648\u0644\u0629. \u0641\u064a \u0647\u0630\u0627 \u0627\u0644\u0628\u0631\u0646\u0627\u0645\u062c \u0627\u0644\u062a\u0639\u0644\u064a\u0645\u064a\u060c \u0633\u0646\u0634\u0631\u062d \u0643\u064a\u0641\u064a\u0629 \u0646\u0634\u0631 \u062a\u0637\u0628\u064a\u0642 Next.js \u0639\u0644\u0649 \u062e\u0627\u062f\u0645 DigitalOcean \u0628\u0627\u0633\u062a\u062e\u062f\u0627\u0645 Nginx \u0643\u0648\u0643\u064a\u0644 \u0639\u0643\u0633\u064a. \u064a\u0641\u062a\u0631\u0636 \u0647\u0630\u0627 \u0627\u0644\u062f\u0644\u064a\u0644 \u0627\u0644\u062a\u0641\u0635\u064a\u0644\u064a \u0623\u0646 \u0644\u062f\u064a\u0643 \u062a\u0637\u0628\u064a\u0642 Next.js \u062c\u0627\u0647\u0632\u064b\u0627 \u0644\u0644\u0646\u0634\u0631 \u0648\u062d\u0633\u0627\u0628\u064b\u0627 \u0639\u0644\u0649 DigitalOcean.<\/p>\n<h5 id=\"%d9%be%db%8c%d8%b4-%d9%86%db%8c%d8%a7%d8%b2%d9%87%d8%a7\">\u0627\u0644\u0645\u062a\u0637\u0644\u0628\u0627\u062a \u0627\u0644\u0623\u0633\u0627\u0633\u064a\u0629<\/h5>\n<ul>\n<li>\u062a\u0637\u0628\u064a\u0642 Next.js<\/li>\n<li>\u062d\u0633\u0627\u0628 DigitalOcean<\/li>\n<li>\u0627\u0633\u0645 \u0627\u0644\u0646\u0637\u0627\u0642 \u0627\u0644\u0645\u0633\u062c\u0644 (\u0627\u062e\u062a\u064a\u0627\u0631\u064a \u0648\u0644\u0643\u0646 \u064a\u0648\u0635\u0649 \u0628\u0647)<\/li>\n<li>\u0627\u0644\u062a\u062b\u0628\u064a\u062a \u0627\u0644\u0645\u062d\u0644\u064a \u0644\u0640 Node.js \u0648 npm \u0623\u0648 yarn<\/li>\n<\/ul>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-1-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-digitalocean-droplet\">\u0627\u0644\u062e\u0637\u0648\u0629 1: \u0625\u0646\u0634\u0627\u0621 \u0642\u0637\u0631\u0629 DigitalOcean<\/h2>\n<p>\u0633\u0646\u0633\u062a\u0636\u064a\u0641 \u062a\u0637\u0628\u064a\u0642 Next.js \u0639\u0644\u0649 \u0645\u0646\u0635\u0629 DigitalOcean Droplet \u0627\u0644\u062a\u064a \u0633\u0646\u0642\u0648\u0645 \u0628\u062a\u0643\u0648\u064a\u0646\u0647\u0627 \u0628\u0623\u0646\u0641\u0633\u0646\u0627. \u0644\u0646\u0628\u062f\u0623 \u0627\u0644\u0622\u0646 \u0628\u0625\u0646\u0634\u0627\u0621 \u0627\u0644\u0645\u0646\u0635\u0629.<\/p>\n<ul>\n<li>\u0642\u0645 \u0628\u062a\u0633\u062c\u064a\u0644 \u0627\u0644\u062f\u062e\u0648\u0644 \u0625\u0644\u0649 \u062d\u0633\u0627\u0628 DigitalOcean \u0627\u0644\u062e\u0627\u0635 \u0628\u0643 \u0648\u0627\u0646\u062a\u0642\u0644 \u0625\u0644\u0649 \u0642\u0633\u0645 Droplets.<\/li>\n<li>\u0627\u0646\u0642\u0631 \u0641\u0648\u0642 &quot;\u0625\u0646\u0634\u0627\u0621 DROPLET&quot;.<\/li>\n<li>\u062d\u062f\u062f \u0635\u0648\u0631\u0629 Ubuntu (\u064a\u0641\u0636\u0644 \u0623\u062d\u062f\u062b \u0625\u0635\u062f\u0627\u0631 LTS).<\/li>\n<li>\u0627\u062e\u062a\u0631 \u062d\u062c\u0645 \u0627\u0644\u0642\u0637\u0631\u0629 \u0627\u0644\u0645\u0637\u0644\u0648\u0628 \u0648\u0641\u0642\u064b\u0627 \u0644\u0627\u062d\u062a\u064a\u0627\u062c\u0627\u062a\u0643 \u0648\u0645\u064a\u0632\u0627\u0646\u064a\u062a\u0643.<\/li>\n<li>\u0644\u0644\u062d\u0635\u0648\u0644 \u0639\u0644\u0649 \u0623\u062f\u0627\u0621 \u0623\u0641\u0636\u0644\u060c \u0627\u062e\u062a\u0631 \u0645\u0646\u0637\u0642\u0629 \u0645\u0631\u0643\u0632 \u0627\u0644\u0628\u064a\u0627\u0646\u0627\u062a \u0627\u0644\u0623\u0642\u0631\u0628 \u0644\u062c\u0645\u0647\u0648\u0631\u0643 \u0627\u0644\u0645\u0633\u062a\u0647\u062f\u0641.<\/li>\n<li>\u0623\u0636\u0641 \u0645\u0641\u0627\u062a\u064a\u062d SSH \u0627\u0644\u062e\u0627\u0635\u0629 \u0628\u0643 \u0644\u0644\u0648\u0635\u0648\u0644 \u0627\u0644\u0622\u0645\u0646 \u0625\u0644\u0649 Droplet \u0627\u0644\u062e\u0627\u0635 \u0628\u0643.<\/li>\n<li>\u0627\u062e\u062a\u0631 \u0627\u0633\u0645 \u0645\u0636\u064a\u0641 \u0644\u0642\u0637\u0631\u062a\u0643\u060c \u0648\u0627\u0644\u0630\u064a \u064a\u0645\u0643\u0646 \u0623\u0646 \u064a\u0643\u0648\u0646 \u0627\u0633\u0645 \u0627\u0644\u0645\u062c\u0627\u0644 \u0627\u0644\u062e\u0627\u0635 \u0628\u0643 \u0623\u0648 \u0623\u064a \u0627\u0633\u0645 \u0645\u0641\u0636\u0644.<\/li>\n<li>\u0627\u0646\u0642\u0631 \u0641\u0648\u0642 &quot;\u0625\u0646\u0634\u0627\u0621 DROPLET&quot;.<\/li>\n<li>\u0625\u0646\u0634\u0627\u0621 \u0627\u0644\u0642\u0637\u0631\u0629<\/li>\n<\/ul>\n<p><img  loading=\"lazy\"  decoding=\"async\"  src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABAQMAAAAl21bKAAAAA1BMVEUAAP+KeNJXAAAAAXRSTlMAQObYZgAAAAlwSFlzAAAOxAAADsQBlSsOGwAAAApJREFUCNdjYAAAAAIAAeIhvDMAAAAASUVORK5CYII=\"  alt=\"\"  width=\"1350\"  height=\"1182\"  class=\"aligncenter wp-image-15639 size-full pk-lazyload\"  data-pk-sizes=\"auto\"  data-ls-sizes=\"auto, (max-width: 1350px) 100vw, 1350px\"  data-pk-src=\"https:\/\/cdn.itpiran.net\/2024\/06\/04151644\/create-droplet.png\"  data-pk-srcset=\"https:\/\/cdn.itpiran.net\/2024\/06\/04151644\/create-droplet.png 1350w, https:\/\/cdn.itpiran.net\/2024\/06\/04151644\/create-droplet-300x263.png 300w, https:\/\/cdn.itpiran.net\/2024\/06\/04151644\/create-droplet-1024x897.png 1024w, https:\/\/cdn.itpiran.net\/2024\/06\/04151644\/create-droplet-768x672.png 768w, https:\/\/cdn.itpiran.net\/2024\/06\/04151644\/create-droplet-110x96.png 110w, https:\/\/cdn.itpiran.net\/2024\/06\/04151644\/create-droplet-200x175.png 200w, https:\/\/cdn.itpiran.net\/2024\/06\/04151644\/create-droplet-380x333.png 380w, https:\/\/cdn.itpiran.net\/2024\/06\/04151644\/create-droplet-255x223.png 255w, https:\/\/cdn.itpiran.net\/2024\/06\/04151644\/create-droplet-550x482.png 550w, https:\/\/cdn.itpiran.net\/2024\/06\/04151644\/create-droplet-800x700.png 800w, https:\/\/cdn.itpiran.net\/2024\/06\/04151644\/create-droplet-1160x1016.png 1160w\" ><\/p>\n<p>\u0628\u0639\u062f \u0625\u0646\u0634\u0627\u0621 Droplet\u060c \u0644\u0627\u062d\u0638 \u0639\u0646\u0648\u0627\u0646 IP \u0627\u0644\u0645\u062e\u0635\u0635 \u0644\u0647.<\/p>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-2-%d8%b1%d8%a7%d9%87-%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c-droplet\">\u0627\u0644\u062e\u0637\u0648\u0629 2: \u062a\u0634\u063a\u064a\u0644 Droplet<\/h2>\n<p>\u0627\u0644\u0622\u0646 \u0628\u0639\u062f \u0623\u0646 \u0642\u0645\u0646\u0627 \u0628\u0625\u0646\u0634\u0627\u0621 \u0627\u0644\u0642\u0637\u0631\u0629\u060c \u0646\u062d\u062a\u0627\u062c \u0625\u0644\u0649 \u0625\u0639\u062f\u0627\u062f\u0647\u0627 \u062d\u062a\u0649 \u062a\u062a\u0645\u0643\u0646 \u0645\u0646 \u0642\u0628\u0648\u0644 \u0627\u0644\u0627\u062a\u0635\u0627\u0644\u0627\u062a \u0627\u0644\u0648\u0627\u0631\u062f\u0629 \u0648\u062a\u0648\u062c\u064a\u0647 \u062a\u0644\u0643 \u0627\u0644\u0627\u062a\u0635\u0627\u0644\u0627\u062a \u0625\u0644\u0649 \u062a\u0637\u0628\u064a\u0642 Next.js \u0627\u0644\u062e\u0627\u0635 \u0628\u0646\u0627.<\/p>\n<p>\u0642\u0645 \u0628\u062a\u0633\u062c\u064a\u0644 \u0627\u0644\u062f\u062e\u0648\u0644 \u0625\u0644\u0649 Droplet \u0627\u0644\u062e\u0627\u0635 \u0628\u0643 \u0639\u0628\u0631 SSH \u0628\u0627\u0633\u062a\u062e\u062f\u0627\u0645 \u0639\u0646\u0648\u0627\u0646 IP \u0648\u0645\u0641\u062a\u0627\u062d SSH \u0627\u0644\u0630\u064a \u0642\u062f\u0645\u062a\u0647 \u0623\u062b\u0646\u0627\u0621 \u0625\u0646\u0634\u0627\u0621 Droplet:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>ssh root@&lt;DROPLET_IP&gt;\r\n<\/code><\/pre>\n<\/div>\n<p>\u062a\u062d\u062f\u064a\u062b \u0648\u062a\u0631\u0642\u064a\u0629 \u0627\u0644\u062d\u0632\u0645 \u0641\u064a Droplet:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>sudo apt update &amp;&amp; sudo apt upgrade -y\r\n<\/code><\/pre>\n<\/div>\n<p>\u062a\u062b\u0628\u064a\u062a \u0627\u0644\u062d\u0632\u0645 \u0627\u0644\u0645\u0637\u0644\u0648\u0628\u0629:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>sudo apt install -y nodejs npm nginx\r\n<\/code><\/pre>\n<\/div>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-3-%d9%be%db%8c%da%a9%d8%b1%d8%a8%d9%86%d8%af%db%8c-nginx\">\u0627\u0644\u062e\u0637\u0648\u0629 3: \u062a\u0643\u0648\u064a\u0646 Nginx<\/h2>\n<p>Nginx \u0647\u064a \u0627\u0644\u0623\u062f\u0627\u0629 \u0627\u0644\u0645\u0633\u0624\u0648\u0644\u0629 \u0639\u0646 \u062a\u0648\u062c\u064a\u0647 \u062c\u0645\u064a\u0639 \u0639\u0645\u0644\u064a\u0627\u062a \u062a\u0637\u0628\u064a\u0642 Next.js. \u0623\u0646\u0634\u0626 \u0645\u0644\u0641 \u062a\u0647\u064a\u0626\u0629 Nginx \u062c\u062f\u064a\u062f\u064b\u0627 \u0644\u062a\u0637\u0628\u064a\u0642 Next.js:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>sudo nano \/etc\/nginx\/sites-available\/nextjs\r\n<\/code><\/pre>\n<\/div>\n<p>\u0642\u0645 \u0628\u0644\u0635\u0642 \u0627\u0644\u062a\u0643\u0648\u064a\u0646 \u0627\u0644\u062a\u0627\u0644\u064a\u060c \u0648\u0627\u0633\u062a\u0628\u062f\u0627\u0644 server_name \u0628\u0627\u0633\u0645 \u0646\u0637\u0627\u0642 Droplet \u0627\u0644\u062e\u0627\u0635 \u0628\u0643 \u0623\u0648 \u0639\u0646\u0648\u0627\u0646 IP:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-plain\" data-lang=\"Plain Text\"><code>server {\r\nlisten 80;\r\nserver_name YOUR_IP_ADDRESS;\r\nlocation \/ {\r\nproxy_pass http:\/\/localhost:3000;\r\nproxy_http_version 1.1;\r\nproxy_set_header Upgrade $http_upgrade;\r\nproxy_set_header Connection 'upgrade';\r\nproxy_set_header Host $host;\r\nproxy_cache_bypass $http_upgrade;\r\n}\r\n}<\/code><\/pre>\n<\/div>\n<p>\u0627\u062d\u0641\u0638 \u0627\u0644\u0645\u0644\u0641 \u0648\u0623\u063a\u0644\u0642\u0647. \u0623\u0646\u0634\u0626 \u0631\u0627\u0628\u0637\u064b\u0627 \u0631\u0645\u0632\u064a\u064b\u0627 \u0644\u062a\u0641\u0639\u064a\u0644 \u0627\u0644\u062a\u0643\u0648\u064a\u0646:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>sudo ln -s \/etc\/nginx\/sites-available\/nextjs \/etc\/nginx\/sites-enabled\/\r\n<\/code><\/pre>\n<\/div>\n<p>\u0627\u062e\u062a\u0628\u0627\u0631 \u062a\u0643\u0648\u064a\u0646 Nginx \u0628\u062d\u062b\u064b\u0627 \u0639\u0646 \u0623\u064a \u0623\u062e\u0637\u0627\u0621 \u0646\u062d\u0648\u064a\u0629:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>sudo nginx -t\r\n<\/code><\/pre>\n<\/div>\n<p><img  loading=\"lazy\"  decoding=\"async\"  src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABAQMAAAAl21bKAAAAA1BMVEUAAP+KeNJXAAAAAXRSTlMAQObYZgAAAAlwSFlzAAAOxAAADsQBlSsOGwAAAApJREFUCNdjYAAAAAIAAeIhvDMAAAAASUVORK5CYII=\"  alt=\"\"  width=\"1686\"  height=\"440\"  class=\"aligncenter wp-image-15640 size-full pk-lazyload\"  data-pk-sizes=\"auto\"  data-ls-sizes=\"auto, (max-width: 1686px) 100vw, 1686px\"  data-pk-src=\"https:\/\/cdn.itpiran.net\/2024\/06\/04152205\/check-nginx-config.png\"  data-pk-srcset=\"https:\/\/cdn.itpiran.net\/2024\/06\/04152205\/check-nginx-config.png 1686w, https:\/\/cdn.itpiran.net\/2024\/06\/04152205\/check-nginx-config-300x78.png 300w, https:\/\/cdn.itpiran.net\/2024\/06\/04152205\/check-nginx-config-1024x267.png 1024w, https:\/\/cdn.itpiran.net\/2024\/06\/04152205\/check-nginx-config-768x200.png 768w, https:\/\/cdn.itpiran.net\/2024\/06\/04152205\/check-nginx-config-1536x401.png 1536w, https:\/\/cdn.itpiran.net\/2024\/06\/04152205\/check-nginx-config-110x29.png 110w, https:\/\/cdn.itpiran.net\/2024\/06\/04152205\/check-nginx-config-200x52.png 200w, https:\/\/cdn.itpiran.net\/2024\/06\/04152205\/check-nginx-config-380x99.png 380w, https:\/\/cdn.itpiran.net\/2024\/06\/04152205\/check-nginx-config-255x67.png 255w, https:\/\/cdn.itpiran.net\/2024\/06\/04152205\/check-nginx-config-550x144.png 550w, https:\/\/cdn.itpiran.net\/2024\/06\/04152205\/check-nginx-config-800x209.png 800w, https:\/\/cdn.itpiran.net\/2024\/06\/04152205\/check-nginx-config-1160x303.png 1160w\" ><\/p>\n<p>\u0625\u0630\u0627 \u0643\u0627\u0646 \u0627\u062e\u062a\u0628\u0627\u0631 \u0627\u0644\u062a\u0643\u0648\u064a\u0646 \u0646\u0627\u062c\u062d\u064b\u0627\u060c \u0641\u0623\u0639\u062f \u062a\u0634\u063a\u064a\u0644 Nginx:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>sudo service nginx restart\r\n<\/code><\/pre>\n<\/div>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-4-%d8%a7%d8%b3%d8%aa%d9%82%d8%b1%d8%a7%d8%b1-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-next-js\">\u0627\u0644\u062e\u0637\u0648\u0629 4: \u0646\u0634\u0631 \u062a\u0637\u0628\u064a\u0642 Next.js<\/h2>\n<p>\u0628\u0639\u062f \u0630\u0644\u0643\u060c \u0633\u0646\u0636\u064a\u0641 \u062a\u0637\u0628\u064a\u0642 Next.js \u0625\u0644\u0649 Droplet. \u0647\u0646\u0627\u0643 \u062e\u064a\u0627\u0631\u0627\u062a \u0639\u062f\u064a\u062f\u0629 \u0644\u0644\u0642\u064a\u0627\u0645 \u0628\u0630\u0644\u0643.<\/p>\n<ol>\n<li>\u0642\u0645 \u0628\u0625\u0646\u0634\u0627\u0621 \u0645\u0641\u062a\u0627\u062d SSH \u0639\u0644\u0649 \u0627\u0644\u062e\u0627\u062f\u0645\u060c \u0648\u0642\u0645 \u0628\u062a\u0648\u0635\u064a\u0644\u0647 \u0628\u062d\u0633\u0627\u0628 GitHub \u0627\u0644\u062e\u0627\u0635 \u0628\u0643\u060c \u062b\u0645 \u0627\u0633\u062a\u0646\u0633\u062e \u0645\u0633\u062a\u0648\u062f\u0639\u0643.<\/li>\n<li>\u0625\u0646\u0634\u0627\u0621 \u062a\u0637\u0628\u064a\u0642 Next.js \u0641\u064a Droplet<\/li>\n<\/ol>\n<p>\u0641\u064a \u0647\u0630\u0627 \u0627\u0644\u0628\u0631\u0646\u0627\u0645\u062c \u0627\u0644\u062a\u0639\u0644\u064a\u0645\u064a\u060c \u0633\u0646\u0642\u0648\u0645 \u0628\u0625\u0646\u0634\u0627\u0621 \u062a\u0637\u0628\u064a\u0642 Next.js \u062c\u062f\u064a\u062f \u0641\u064a Droplet \u0627\u0644\u062e\u0627\u0635 \u0628\u0646\u0627.<\/p>\n<p>\u0627\u0644\u0639\u0648\u062f\u0629 \u0625\u0644\u0649 Droplet \u0627\u0644\u062e\u0627\u0635 \u0628\u0643 \u0639\u0628\u0631 SSH:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>ssh root@&lt;DROPLET_IP&gt;\r\n<\/code><\/pre>\n<\/div>\n<p>\u0642\u0645 \u0628\u0625\u0646\u0634\u0627\u0621 \u062a\u0637\u0628\u064a\u0642 Next.js \u062c\u062f\u064a\u062f \u0648\u0627\u062a\u0628\u0639 \u0627\u0644\u062a\u0639\u0644\u064a\u0645\u0627\u062a:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>cd \/var\/www\r\nnpx create-next-app nextjs<\/code><\/pre>\n<\/div>\n<p>\u0627\u0646\u062a\u0642\u0644 \u0625\u0644\u0649 \u062f\u0644\u064a\u0644 \u062a\u0637\u0628\u064a\u0642 Next.js:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>cd nextjs\r\n<\/code><\/pre>\n<\/div>\n<p>\u062a\u062b\u0628\u064a\u062a \u062a\u0628\u0639\u064a\u0627\u062a \u0627\u0644\u0628\u0631\u0646\u0627\u0645\u062c:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>npm install\r\n<\/code><\/pre>\n<\/div>\n<p>\u0625\u0646\u0634\u0627\u0621 \u062a\u0637\u0628\u064a\u0642 Next.js:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>npm run build\r\n<\/code><\/pre>\n<\/div>\n<p>\u0648\u0623\u062e\u064a\u0631\u064b\u0627\u060c \u0642\u0645 \u0628\u062a\u0634\u063a\u064a\u0644 \u062a\u0637\u0628\u064a\u0642 Next.js:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>npm start\r\n<\/code><\/pre>\n<\/div>\n<p>\u062a\u0645 \u0627\u0644\u0622\u0646 \u0646\u0634\u0631 \u062a\u0637\u0628\u064a\u0642 Next.js \u0627\u0644\u062e\u0627\u0635 \u0628\u0643 \u0648\u064a\u0645\u0643\u0646 \u0627\u0644\u0648\u0635\u0648\u0644 \u0625\u0644\u064a\u0647 \u0639\u0628\u0631 \u0627\u0633\u0645 \u0646\u0637\u0627\u0642 Droplet \u0623\u0648 \u0639\u0646\u0648\u0627\u0646 IP \u0627\u0644\u062e\u0627\u0635 \u0628\u0643. \u0644\u062a\u0634\u063a\u064a\u0644 \u062a\u0637\u0628\u064a\u0642\u0643 \u0641\u064a \u0627\u0644\u062e\u0644\u0641\u064a\u0629 \u0648\u0625\u0639\u0627\u062f\u0629 \u062a\u0634\u063a\u064a\u0644\u0647 \u062a\u0644\u0642\u0627\u0626\u064a\u064b\u0627 \u0639\u0646\u062f \u062a\u0639\u0637\u0644 \u0627\u0644\u062e\u0627\u062f\u0645 \u0623\u0648 \u0625\u0639\u0627\u062f\u0629 \u062a\u0634\u063a\u064a\u0644\u0647\u060c \u0633\u062a\u062d\u062a\u0627\u062c \u0625\u0644\u0649 \u0627\u0633\u062a\u062e\u062f\u0627\u0645 \u0645\u062f\u064a\u0631 \u0639\u0645\u0644\u064a\u0627\u062a \u0645\u062b\u0644 PM2.<\/p>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-5-%d8%b1%d8%a7%d9%87-%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c-pm2-process-manager\">\u0627\u0644\u062e\u0637\u0648\u0629 5: \u062a\u0634\u063a\u064a\u0644 PM2 Process Manager<\/h2>\n<p>\u0628\u062f\u0623\u0646\u0627 \u062a\u0634\u063a\u064a\u0644 npm \u0645\u0646 \u062f\u0627\u062e\u0644 Droplet. \u0642\u062f \u064a\u062a\u0648\u0642\u0641 \u0647\u0630\u0627 \u0627\u0644\u0623\u0645\u0631 \u0623\u062d\u064a\u0627\u0646\u064b\u0627 \u0644\u0623\u0633\u0628\u0627\u0628 \u0645\u062b\u0644 \u0625\u0639\u0627\u062f\u0629 \u062a\u0634\u063a\u064a\u0644 \u0627\u0644\u062e\u0627\u062f\u0645 \u0623\u0648 \u0627\u0644\u062d\u0627\u062c\u0629 \u0625\u0644\u0649 \u062a\u062b\u0628\u064a\u062a \u062a\u062d\u062f\u064a\u062b. \u0633\u0646\u0633\u062a\u062e\u062f\u0645 \u0623\u062f\u0627\u0629 PM2 \u0644\u0636\u0645\u0627\u0646 \u0627\u0633\u062a\u0645\u0631\u0627\u0631 \u062a\u0634\u063a\u064a\u0644 \u062a\u0637\u0628\u064a\u0642 Next.js. \u0633\u062a\u064f\u0639\u0627\u062f \u062a\u0634\u063a\u064a\u0644 PM2 \u062d\u062a\u0649 \u0641\u064a \u062d\u0627\u0644\u0629 \u062a\u0639\u0637\u0644 \u062a\u0637\u0628\u064a\u0642 Next.js.<\/p>\n<p>\u0644\u062a\u062b\u0628\u064a\u062a PM2 \u0639\u0627\u0644\u0645\u064a\u064b\u0627 \u0639\u0644\u0649 \u0627\u0644\u0642\u0637\u0631\u0629 \u0627\u0644\u062e\u0627\u0635\u0629 \u0628\u0643:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>sudo npm install -g pm2\r\n<\/code><\/pre>\n<\/div>\n<p>\u0627\u0646\u062a\u0642\u0644 \u0625\u0644\u0649 \u062f\u0644\u064a\u0644 \u062a\u0637\u0628\u064a\u0642 Next.js (\u0625\u0630\u0627 \u0644\u0645 \u064a\u0643\u0646 \u0645\u0648\u062c\u0648\u062f\u064b\u0627 \u0647\u0646\u0627\u0643 \u0628\u0627\u0644\u0641\u0639\u0644):<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>cd \/var\/www\/nextjs\r\n<\/code><\/pre>\n<\/div>\n<p>\u0627\u0628\u062f\u0623 \u062a\u0637\u0628\u064a\u0642 Next.js \u0628\u0627\u0633\u062a\u062e\u062f\u0627\u0645 PM2:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>pm2 start npm --name \"nextjs\" -- start\r\n<\/code><\/pre>\n<\/div>\n<p>\u064a\u064f\u0634\u063a\u0651\u0644 \u0647\u0630\u0627 \u0627\u0644\u0623\u0645\u0631 \u062a\u0637\u0628\u064a\u0642 Next.js \u0627\u0644\u0645\u0633\u0645\u0649 &quot;nextjs&quot; \u0628\u0627\u0633\u062a\u062e\u062f\u0627\u0645 \u0623\u0645\u0631 npm start. \u0633\u064a\u064f\u0639\u064a\u062f PM2 \u062a\u0634\u063a\u064a\u0644 \u0627\u0644\u062a\u0637\u0628\u064a\u0642 \u062a\u0644\u0642\u0627\u0626\u064a\u064b\u0627 \u0641\u064a \u062d\u0627\u0644 \u062a\u0639\u0637\u0644 \u0627\u0644\u062e\u0627\u062f\u0645 \u0623\u0648 \u0625\u0639\u0627\u062f\u0629 \u062a\u0634\u063a\u064a\u0644\u0647.<\/p>\n<p>\u0644\u062a\u062a\u0623\u0643\u062f \u0645\u0646 \u0628\u062f\u0621 \u062a\u0634\u063a\u064a\u0644 PM2 \u0639\u0646\u062f \u0628\u062f\u0621 \u0627\u0644\u062a\u0634\u063a\u064a\u0644\u060c \u0642\u0645 \u0628\u062a\u0634\u063a\u064a\u0644:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>pm2 startup\r\n<\/code><\/pre>\n<\/div>\n<p>\u0633\u064a\u0624\u062f\u064a \u0647\u0630\u0627 \u0627\u0644\u0623\u0645\u0631 \u0625\u0644\u0649 \u0625\u0646\u0634\u0627\u0621 \u0646\u0635 \u0628\u0631\u0645\u062c\u064a \u064a\u0645\u0643\u0646\u0643 \u0646\u0633\u062e\u0647 \u0648\u0644\u0635\u0642\u0647 \u0641\u064a \u0645\u062d\u0637\u062a\u0643 \u0644\u0628\u062f\u0621 \u062a\u0634\u063a\u064a\u0644 PM2 \u0641\u064a \u0648\u0642\u062a \u0627\u0644\u062a\u0645\u0647\u064a\u062f.<\/p>\n<p>\u062d\u0641\u0638 \u0639\u0645\u0644\u064a\u0627\u062a PM2 \u0627\u0644\u062d\u0627\u0644\u064a\u0629:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>pm2 save\r\n<\/code><\/pre>\n<\/div>\n<h2 id=\"%d9%86%d8%aa%db%8c%d8%ac%d9%87\">\u0646\u062a\u064a\u062c\u0629<\/h2>\n<p><img  loading=\"lazy\"  decoding=\"async\"  src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABAQMAAAAl21bKAAAAA1BMVEUAAP+KeNJXAAAAAXRSTlMAQObYZgAAAAlwSFlzAAAOxAAADsQBlSsOGwAAAApJREFUCNdjYAAAAAIAAeIhvDMAAAAASUVORK5CYII=\"  alt=\"\"  width=\"2722\"  height=\"1976\"  class=\"aligncenter wp-image-15641 size-full pk-lazyload\"  data-pk-sizes=\"auto\"  data-ls-sizes=\"auto, (max-width: 2722px) 100vw, 2722px\"  data-pk-src=\"https:\/\/cdn.itpiran.net\/2024\/06\/04153049\/nextjs-site.png\"  data-pk-srcset=\"https:\/\/cdn.itpiran.net\/2024\/06\/04153049\/nextjs-site.png 2722w, https:\/\/cdn.itpiran.net\/2024\/06\/04153049\/nextjs-site-300x218.png 300w, https:\/\/cdn.itpiran.net\/2024\/06\/04153049\/nextjs-site-1024x743.png 1024w, https:\/\/cdn.itpiran.net\/2024\/06\/04153049\/nextjs-site-768x558.png 768w, https:\/\/cdn.itpiran.net\/2024\/06\/04153049\/nextjs-site-1536x1115.png 1536w, https:\/\/cdn.itpiran.net\/2024\/06\/04153049\/nextjs-site-2048x1487.png 2048w, https:\/\/cdn.itpiran.net\/2024\/06\/04153049\/nextjs-site-110x80.png 110w, https:\/\/cdn.itpiran.net\/2024\/06\/04153049\/nextjs-site-200x145.png 200w, https:\/\/cdn.itpiran.net\/2024\/06\/04153049\/nextjs-site-380x276.png 380w, https:\/\/cdn.itpiran.net\/2024\/06\/04153049\/nextjs-site-255x185.png 255w, https:\/\/cdn.itpiran.net\/2024\/06\/04153049\/nextjs-site-550x399.png 550w, https:\/\/cdn.itpiran.net\/2024\/06\/04153049\/nextjs-site-800x581.png 800w, https:\/\/cdn.itpiran.net\/2024\/06\/04153049\/nextjs-site-1160x842.png 1160w\" ><\/p>\n<p>\u0644\u0642\u062f \u0646\u062c\u062d\u062a \u0627\u0644\u0622\u0646 \u0641\u064a \u062a\u0634\u063a\u064a\u0644 \u062a\u0637\u0628\u064a\u0642 Next.js \u0639\u0644\u0649 \u062e\u0627\u062f\u0645 DigitalOcean \u0628\u0627\u0633\u062a\u062e\u062f\u0627\u0645 Nginx \u0643\u0648\u0643\u064a\u0644 \u0639\u0643\u0633\u064a \u0648PM2 \u0643\u0645\u062f\u064a\u0631 \u0639\u0645\u0644\u064a\u0627\u062a. \u064a\u062c\u0628 \u0623\u0646 \u064a\u0643\u0648\u0646 \u062a\u0637\u0628\u064a\u0642\u0643 \u0645\u062a\u0627\u062d\u064b\u0627 \u0639\u0628\u0631 \u0627\u0633\u0645 \u0646\u0637\u0627\u0642 \u062e\u0627\u062f\u0645\u0643 \u0623\u0648 \u0639\u0646\u0648\u0627\u0646 IP.<\/p>\n<p>\u0625\u0630\u0627 \u0643\u0646\u062a \u062a\u0633\u062a\u062e\u062f\u0645 \u0627\u0633\u0645 \u0646\u0637\u0627\u0642\u060c \u0641\u062a\u0630\u0643\u0631 \u0636\u0628\u0637 \u0625\u0639\u062f\u0627\u062f\u0627\u062a DNS. \u0648\u062c\u0651\u0647 \u0633\u062c\u0644 A \u0627\u0644\u062e\u0627\u0635 \u0628\u0646\u0637\u0627\u0642\u0643 \u0625\u0644\u0649 \u0639\u0646\u0648\u0627\u0646 IP \u0627\u0644\u062e\u0627\u0635 \u0628\u062c\u0647\u0627\u0632\u0643 \u0644\u062a\u062a\u0645\u0643\u0646 \u0645\u0646 \u0627\u0644\u0648\u0635\u0648\u0644 \u0625\u0644\u0649 \u0627\u0644\u062a\u0637\u0628\u064a\u0642 \u0628\u0627\u0633\u062a\u062e\u062f\u0627\u0645 \u0627\u0633\u0645 \u0627\u0644\u0646\u0637\u0627\u0642.<\/p>\n<p>\u0644\u062a\u062d\u0633\u064a\u0646 \u0627\u0644\u0623\u0645\u0627\u0646 \u0648\u062a\u062d\u0633\u064a\u0646 \u0645\u062d\u0631\u0643\u0627\u062a \u0627\u0644\u0628\u062d\u062b\u060c \u0641\u0643\u0651\u0631 \u0641\u064a \u0625\u0639\u062f\u0627\u062f \u0634\u0647\u0627\u062f\u0627\u062a SSL \u0628\u0627\u0633\u062a\u062e\u062f\u0627\u0645 Let&#039;s Encrypt \u0648\u062a\u0646\u0641\u064a\u0630 \u0627\u062a\u0635\u0627\u0644\u0627\u062a HTTPS. \u0628\u0627\u0644\u0625\u0636\u0627\u0641\u0629 \u0625\u0644\u0649 \u0630\u0644\u0643\u060c \u064a\u0645\u0643\u0646\u0643 \u0627\u0633\u062a\u0643\u0634\u0627\u0641 \u062a\u062d\u0633\u064a\u0646 \u062a\u0637\u0628\u064a\u0642 Next.js \u0628\u0627\u0633\u062a\u062e\u062f\u0627\u0645 \u0627\u0644\u062a\u062e\u0632\u064a\u0646 \u0627\u0644\u0645\u0624\u0642\u062a \u0648\u062a\u062d\u0633\u064a\u0646\u0627\u062a \u0627\u0644\u0623\u062f\u0627\u0621 \u0627\u0644\u0623\u062e\u0631\u0649.<\/p>","protected":false},"excerpt":{"rendered":"\u0645\u0642\u062f\u0645\u0629 \u0625\u0644\u0649 Next.js\u060c \u0625\u0637\u0627\u0631 \u0639\u0645\u0644 React \u0627\u0644\u0634\u0647\u064a\u0631 \u0644\u0628\u0646\u0627\u0621 \u062a\u0637\u0628\u064a\u0642\u0627\u062a React \u0627\u0644\u0645\u0642\u062f\u0645\u0629 \u0645\u0646 \u0627\u0644\u062e\u0627\u062f\u0645 \u0628\u0633\u0647\u0648\u0644\u0629...","protected":false},"author":1,"featured_media":15642,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_yoast_wpseo_focuskw":"\u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 Next.js \u062f\u0631 DigitalOcean Droplet","_yoast_wpseo_title":"","_yoast_wpseo_metadesc":"","_yoast_wpseo_canonical":"","_yoast_wpseo_opengraph-description":"","_yoast_wpseo_opengraph-image":"","_yoast_wpseo_twitter-description":"","_yoast_wpseo_twitter-image":"","_yoast_wpseo_focuskeywords":"","_yoast_wpseo_primary_category":"193","footnotes":""},"categories":[193,363],"tags":[401,428],"class_list":{"0":"post-15638","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"has-post-thumbnail","7":"category-tutorials","8":"category-programming","9":"tag-digitalocean","10":"tag-next-js"},"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.3 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>\u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 Next.js \u062f\u0631 DigitalOcean Droplet - \u0628\u0644\u0627\u06af ITPiran<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.itpiran.net\/blog\/ar\/tutorials\/deploying-a-next-js-application-on-a-digitalocean-droplet\/\" \/>\n<meta property=\"og:locale\" content=\"ar_AR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 Next.js \u062f\u0631 DigitalOcean Droplet - \u0628\u0644\u0627\u06af ITPiran\" \/>\n<meta property=\"og:description\" content=\"\u0645\u0642\u062f\u0645\u0647 Next.js \u06cc\u06a9 \u0641\u0631\u06cc\u0645 \u0648\u0631\u06a9 \u0645\u062d\u0628\u0648\u0628 React \u0628\u0631\u0627\u06cc \u0633\u0627\u062e\u062a \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc React \u0631\u0646\u062f\u0631 \u0634\u062f\u0647 \u062a\u0648\u0633\u0637 \u0633\u0631\u0648\u0631 \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc&hellip;\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.itpiran.net\/blog\/ar\/tutorials\/deploying-a-next-js-application-on-a-digitalocean-droplet\/\" \/>\n<meta property=\"og:site_name\" content=\"\u0628\u0644\u0627\u06af ITPiran\" \/>\n<meta property=\"article:published_time\" content=\"2024-06-04T12:09:46+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.itpiran.net\/2024\/06\/04153808\/Dgdrop.jpg\" \/>\n\t<meta property=\"og:image:width\" content=\"1793\" \/>\n\t<meta property=\"og:image:height\" content=\"1110\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/jpeg\" \/>\n<meta name=\"author\" content=\"admin\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u0643\u064f\u062a\u0628 \u0628\u0648\u0627\u0633\u0637\u0629\" \/>\n\t<meta name=\"twitter:data1\" content=\"admin\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u0648\u0642\u062a \u0627\u0644\u0642\u0631\u0627\u0621\u0629 \u0627\u0644\u0645\u064f\u0642\u062f\u0651\u0631\" \/>\n\t<meta name=\"twitter:data2\" content=\"\u062f\u0642\u064a\u0642\u0629 \u0648\u0627\u062d\u062f\u0629\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/deploying-a-next-js-application-on-a-digitalocean-droplet\\\/#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/deploying-a-next-js-application-on-a-digitalocean-droplet\\\/\"},\"author\":{\"name\":\"admin\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/person\\\/04ed27b919baca468a2273f8e4318f81\"},\"headline\":\"\u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 Next.js \u062f\u0631 DigitalOcean Droplet\",\"datePublished\":\"2024-06-04T12:09:46+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/deploying-a-next-js-application-on-a-digitalocean-droplet\\\/\"},\"wordCount\":123,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#organization\"},\"image\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/deploying-a-next-js-application-on-a-digitalocean-droplet\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/06\\\/04153808\\\/Dgdrop.jpg\",\"keywords\":[\"Digitalocean\",\"next.js\"],\"articleSection\":[\"\u0622\u0645\u0648\u0632\u0634\u06cc\",\"\u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc\"],\"inLanguage\":\"ar\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/deploying-a-next-js-application-on-a-digitalocean-droplet\\\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/deploying-a-next-js-application-on-a-digitalocean-droplet\\\/\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/deploying-a-next-js-application-on-a-digitalocean-droplet\\\/\",\"name\":\"\u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 Next.js \u062f\u0631 DigitalOcean Droplet - \u0628\u0644\u0627\u06af ITPiran\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/deploying-a-next-js-application-on-a-digitalocean-droplet\\\/#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/deploying-a-next-js-application-on-a-digitalocean-droplet\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/06\\\/04153808\\\/Dgdrop.jpg\",\"datePublished\":\"2024-06-04T12:09:46+00:00\",\"breadcrumb\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/deploying-a-next-js-application-on-a-digitalocean-droplet\\\/#breadcrumb\"},\"inLanguage\":\"ar\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/deploying-a-next-js-application-on-a-digitalocean-droplet\\\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"ar\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/deploying-a-next-js-application-on-a-digitalocean-droplet\\\/#primaryimage\",\"url\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/06\\\/04153808\\\/Dgdrop.jpg\",\"contentUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/06\\\/04153808\\\/Dgdrop.jpg\",\"width\":1793,\"height\":1110},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/deploying-a-next-js-application-on-a-digitalocean-droplet\\\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u0622\u0645\u0648\u0632\u0634\u06cc\",\"item\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/category\\\/tutorials\\\/\"},{\"@type\":\"ListItem\",\"position\":3,\"name\":\"\u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 Next.js \u062f\u0631 DigitalOcean Droplet\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#website\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/\",\"name\":\"\u0628\u0644\u0627\u06af ITPiran\",\"description\":\"\u0627\u062e\u0628\u0627\u0631 \u0648 \u0645\u0642\u0627\u0644\u0627\u062a \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646\",\"publisher\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"ar\"},{\"@type\":\"Organization\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#organization\",\"name\":\"\u0628\u0644\u0627\u06af \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646\",\"alternateName\":\"ITPIran Blog\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"ar\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\",\"url\":\"https:\\\/\\\/cdn.itpiran.net\\\/2023\\\/12\\\/27150508\\\/cropped-ITPIRAN-BLOG-LOGO-2.png\",\"contentUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2023\\\/12\\\/27150508\\\/cropped-ITPIRAN-BLOG-LOGO-2.png\",\"width\":512,\"height\":512,\"caption\":\"\u0628\u0644\u0627\u06af \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646\"},\"image\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\"}},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/person\\\/04ed27b919baca468a2273f8e4318f81\",\"name\":\"admin\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/ar\\\/author\\\/admin\\\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"\u0646\u0634\u0631 \u062a\u0637\u0628\u064a\u0642 Next.js \u0639\u0644\u0649 DigitalOcean Droplet - \u0645\u062f\u0648\u0646\u0629 ITPiran","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.itpiran.net\/blog\/ar\/tutorials\/deploying-a-next-js-application-on-a-digitalocean-droplet\/","og_locale":"ar_AR","og_type":"article","og_title":"\u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 Next.js \u062f\u0631 DigitalOcean Droplet - \u0628\u0644\u0627\u06af ITPiran","og_description":"\u0645\u0642\u062f\u0645\u0647 Next.js \u06cc\u06a9 \u0641\u0631\u06cc\u0645 \u0648\u0631\u06a9 \u0645\u062d\u0628\u0648\u0628 React \u0628\u0631\u0627\u06cc \u0633\u0627\u062e\u062a \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc React \u0631\u0646\u062f\u0631 \u0634\u062f\u0647 \u062a\u0648\u0633\u0637 \u0633\u0631\u0648\u0631 \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc&hellip;","og_url":"https:\/\/www.itpiran.net\/blog\/ar\/tutorials\/deploying-a-next-js-application-on-a-digitalocean-droplet\/","og_site_name":"\u0628\u0644\u0627\u06af ITPiran","article_published_time":"2024-06-04T12:09:46+00:00","og_image":[{"width":1793,"height":1110,"url":"https:\/\/cdn.itpiran.net\/2024\/06\/04153808\/Dgdrop.jpg","type":"image\/jpeg"}],"author":"admin","twitter_card":"summary_large_image","twitter_misc":{"\u0643\u064f\u062a\u0628 \u0628\u0648\u0627\u0633\u0637\u0629":"admin","\u0648\u0642\u062a \u0627\u0644\u0642\u0631\u0627\u0621\u0629 \u0627\u0644\u0645\u064f\u0642\u062f\u0651\u0631":"\u062f\u0642\u064a\u0642\u0629 \u0648\u0627\u062d\u062f\u0629"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/deploying-a-next-js-application-on-a-digitalocean-droplet\/#article","isPartOf":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/deploying-a-next-js-application-on-a-digitalocean-droplet\/"},"author":{"name":"admin","@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/person\/04ed27b919baca468a2273f8e4318f81"},"headline":"\u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 Next.js \u062f\u0631 DigitalOcean Droplet","datePublished":"2024-06-04T12:09:46+00:00","mainEntityOfPage":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/deploying-a-next-js-application-on-a-digitalocean-droplet\/"},"wordCount":123,"commentCount":0,"publisher":{"@id":"https:\/\/www.itpiran.net\/blog\/#organization"},"image":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/deploying-a-next-js-application-on-a-digitalocean-droplet\/#primaryimage"},"thumbnailUrl":"https:\/\/cdn.itpiran.net\/2024\/06\/04153808\/Dgdrop.jpg","keywords":["Digitalocean","next.js"],"articleSection":["\u0622\u0645\u0648\u0632\u0634\u06cc","\u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc"],"inLanguage":"ar","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/www.itpiran.net\/blog\/tutorials\/deploying-a-next-js-application-on-a-digitalocean-droplet\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/deploying-a-next-js-application-on-a-digitalocean-droplet\/","url":"https:\/\/www.itpiran.net\/blog\/tutorials\/deploying-a-next-js-application-on-a-digitalocean-droplet\/","name":"\u0646\u0634\u0631 \u062a\u0637\u0628\u064a\u0642 Next.js \u0639\u0644\u0649 DigitalOcean Droplet - \u0645\u062f\u0648\u0646\u0629 ITPiran","isPartOf":{"@id":"https:\/\/www.itpiran.net\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/deploying-a-next-js-application-on-a-digitalocean-droplet\/#primaryimage"},"image":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/deploying-a-next-js-application-on-a-digitalocean-droplet\/#primaryimage"},"thumbnailUrl":"https:\/\/cdn.itpiran.net\/2024\/06\/04153808\/Dgdrop.jpg","datePublished":"2024-06-04T12:09:46+00:00","breadcrumb":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/deploying-a-next-js-application-on-a-digitalocean-droplet\/#breadcrumb"},"inLanguage":"ar","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.itpiran.net\/blog\/tutorials\/deploying-a-next-js-application-on-a-digitalocean-droplet\/"]}]},{"@type":"ImageObject","inLanguage":"ar","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/deploying-a-next-js-application-on-a-digitalocean-droplet\/#primaryimage","url":"https:\/\/cdn.itpiran.net\/2024\/06\/04153808\/Dgdrop.jpg","contentUrl":"https:\/\/cdn.itpiran.net\/2024\/06\/04153808\/Dgdrop.jpg","width":1793,"height":1110},{"@type":"BreadcrumbList","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/deploying-a-next-js-application-on-a-digitalocean-droplet\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/www.itpiran.net\/blog\/"},{"@type":"ListItem","position":2,"name":"\u0622\u0645\u0648\u0632\u0634\u06cc","item":"https:\/\/www.itpiran.net\/blog\/category\/tutorials\/"},{"@type":"ListItem","position":3,"name":"\u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 Next.js \u062f\u0631 DigitalOcean Droplet"}]},{"@type":"WebSite","@id":"https:\/\/www.itpiran.net\/blog\/#website","url":"https:\/\/www.itpiran.net\/blog\/","name":"\u0645\u062f\u0648\u0646\u0629 ITPiran","description":"\u0623\u062e\u0628\u0627\u0631 \u0648\u0645\u0642\u0627\u0644\u0627\u062a \u0639\u0646 \u0627\u0644\u062a\u062c\u0627\u0631\u0629 \u0627\u0644\u0645\u0633\u062a\u062f\u0627\u0645\u0629 \u0627\u0644\u0625\u064a\u0631\u0627\u0646\u064a\u0629","publisher":{"@id":"https:\/\/www.itpiran.net\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.itpiran.net\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"ar"},{"@type":"Organization","@id":"https:\/\/www.itpiran.net\/blog\/#organization","name":"\u0645\u062f\u0648\u0646\u0629 \u0627\u0644\u0623\u0639\u0645\u0627\u0644 \u0627\u0644\u0625\u064a\u0631\u0627\u0646\u064a\u0629 \u0627\u0644\u0645\u0633\u062a\u062f\u0627\u0645\u0629","alternateName":"ITPIran Blog","url":"https:\/\/www.itpiran.net\/blog\/","logo":{"@type":"ImageObject","inLanguage":"ar","@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/cdn.itpiran.net\/2023\/12\/27150508\/cropped-ITPIRAN-BLOG-LOGO-2.png","contentUrl":"https:\/\/cdn.itpiran.net\/2023\/12\/27150508\/cropped-ITPIRAN-BLOG-LOGO-2.png","width":512,"height":512,"caption":"\u0628\u0644\u0627\u06af \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646"},"image":{"@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/logo\/image\/"}},{"@type":"Person","@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/person\/04ed27b919baca468a2273f8e4318f81","name":"\u0645\u0633\u0624\u0644","url":"https:\/\/www.itpiran.net\/blog\/ar\/author\/admin\/"}]}},"_links":{"self":[{"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/posts\/15638","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/comments?post=15638"}],"version-history":[{"count":1,"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/posts\/15638\/revisions"}],"predecessor-version":[{"id":15643,"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/posts\/15638\/revisions\/15643"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/media\/15642"}],"wp:attachment":[{"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/media?parent=15638"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/categories?post=15638"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/tags?post=15638"}],"curies":[{"name":"\u0648\u0648\u0631\u062f\u0628\u0631\u064a\u0633","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}