มา Deploy Website แบบไม่เสียตังด้วย Now กันเถอะ
สวัสดีครับ วันนี้จะมาแนะนำบทความสำหรับการ Deploy Website กันแบบง่ายๆด้วย Now กันครับ ซึ่งโดยปกติแล้วบางคนทำเว็บไซต์เสร็จ อยากเอาเว็บขึ้น Cloud ก็ต้องมาหา Hosting สำหรับเทสบ้าง หรือรัน Production จริงๆก็แล้วแต่ ก็ต้องมาเปิด VPS แล้ว Setup ค่อนข้างยุ่งยากเลยทีเดียว
วันนี้ผมก็เลยมาพร้อมกับ Now ทำให้การ Deploy Website ง่ายเพียงแค่ปลายนิ้วคลิ๊ก : ในเว็บ Now เค้าบอกว่า เพียงแค่มีไฟล์ package.json
หรือ Dockerfile
ก็สามารถ Deploy ไปที่ Cloud ด้วยคำสั่ง now
ได้เลย
และ ณ ตอนนี้ ตัว Now รองรับการ Deploy เว็บไซต์ทั้งสิ้น 3 แบบ ก็คือ
ซึ่งก็ต้องทำการติดตั้ง Now ลงเครื่องซะงั้น โชคดีที่ว่า Now มี เวอร์ชั่น Now Desktop ให้เราดาวน์โหลดมาลงเครื่องเลย พร้อมทั้งมี Now CLI ให้พร้อม หรือใครไม่ชอบ GUI ก็จะลงผ่าน npm ก็ได้ เช่นกัน
หลังจากติดตั้ง Now แล้ว จะได้หน้าจอแบบนี้ ก็กรอก Email เพื่อทำการสมัครได้เลย
รอ Verify email ก็เป็นอันเรียบร้อย ได้ Account Now แล้ว
เมื่อพร้อมแล้วไปลุยกันเลย
วิธี 1 : Static Website
วิธีแรกเป็นการ Deploy Web ที่เป็น Static Website ทั่วๆไป ก็คือขอแค่เว็บไซต์เรามีแค่ index.html
ไฟล์เดียว ก็ deploy ได้เลย หรือจะเป็น Project ที่ build จากพวก SPA ทั้งหลาย Angular, React, Vue ก็ได้หมด
ตัวอย่างวิธีนี้ สมมติผมมี ไฟล์ index.html
ในโฟลเดอร์ มีหน้าตาแบบนี้
ก็แค่ลากโฟลเดอร์ไปวางไว้ที่ไอคอน Now
ก็ได้เลย หรือทำการอัพโหลดผ่าน Command Line ด้วย
จะได้ผลลัพธ์และ URL สำหรับเว็บของเรา
ลองเข้า https://static-web-pipixqcpwd.now.sh/ จะเห็นคำว่า Static Website with Now :)
วิธี 2 : Node.js App
วิธีนี้จะใช้การ Deploy ด้วย Node.js ขอแค่เรามีไฟล์ package.json
และไฟล์ *.js
ซักไฟล์ที่เอาไว้รัน Node.js ซึ่งตัวอย่างจะใช้ Express ในการรัน Server ง่ายๆครับ ไฟล์ index.js
โค๊ดก็จะมีดังนี้ (โค๊ดรกๆ ด้านล่างไม่ต้องสนใจนะครับ แค่ผมใส่ inline style เพื่อจัดหน้านิดหน่อยครับ)
ซึ่งตัว package.json
มันจะมีข้อแม้อยู่หน่อยเดียวคือตั้องมี script start หรือว่า now-start
ด้วย เพื่อให้รู้ว่าหลังจาก Deploy แล้วให้ทำอะไร ซึ่งด้านล่าง ก็คือ start
แล้วสั่งให้มันรัน node index.js
Note: อย่าลืมใส่คำสั่ง
"start": "node index.js"
ในpackage.json
นะครับ
จากนั้น Deploy ด้วยคำสั่งเดิม
ตัว Now จะดูว่ามี package.json
มั้ย? ถ้ามีมันจะรันโค๊ดเราด้วย Node.js environment
เมื่อ Deploy เสร็จลองเข้าเว็บดู https://now-node-app-odpshwgsre.now.sh/ หรือลองเข้า /hello
จะได้{ message: 'Hello Now' }
แบบที่เรากำหนดไว้
วิธี 3 : Docker App
วิธีนี้เป็นการ Deploy ด้วย Dockerfile
จะเป็น App ภาษาอะไรก็ได้ อย่างตัวอย่างผม Deploy ด้วย Golang แบบง่ายๆ โดยใช้ไฟล์ hello.go
ด้านล่าง
และ Dockerfile
แบบนี้
จากนั้นก็ทำการ Deploy ด้วย Now
Now จะรู้เลยว่าเรา Deploy Docker มันจะทำการ Pull image มาทำการ Deploy
สุดท้าย Deploy เสร็จ ก็เข้า URL ไปดูผลลัพธ์เลย https://docker-app-qxobaomjcn.now.sh/
คำสั่งเพิ่มเติม
สำหรับด้านล่างเป็นคำสั่ง Now CLI เพิ่มเติมครับ เช่น
now login
สำหรับ login เข้าสู่ระบบ จะได้ link ในการ login เข้าเมล์ของเรา
now ls
เอาไว้ดู list ของ app เราทั้งหมด เช่น ตัวอย่างผลลัพธ์ของผม
now rm <ID>
เอาไว้ลบ app deployments ของเรา เช่น now rm docker-app-qhsgsytezd.now.sh
now --help
เอาไว้ดู Help รวมถึงคำสั่งอื่นๆ ทั้งหมดที่ใช้ได้
สรุป
ถือว่า Now ก็เป็นอีกหนึ่ง Service ฟรีๆ ที่สามารถให้เรา Deploy web ได้ง่ายๆ เช่นเดียวกับ Firebase Hosting, Github Pages เลย ก็นับว่าเป็นอีกตัวเลือกนึงที่น่าสนใจดีครับ เหมาะกับการลองอะไรใหม่ๆ ง่ายๆ แล้วอยากให้เพื่อนเทสแบบไวๆ
ซึ่งข้้อสังเกตข้อนึงเลยคือ ทุกๆครั้งที่เราสั่ง Deploy ด้วย now
ข้อมูลหรือ instance เก่าๆ ก็จะยังอยู่จนกว่าเราจะสั่ง now remove
นะครับ สุดท้ายก็ลองไปดู ราคาของ Now กันดูครับ ว่าจะคุ้มหรือน่าซื้อหรือเปล่า
ซึ่ง Free plan มันก็มีข้อจำกัดคือ ได้ Bandwidth 1GB หรือ Max file size แค่ 1MB ซึ่งผมลอง Deploy ตัว static website ของ React ปรากฎว่าไฟล์ bundle มันใหญ่ไป ไม่สามารถ Deploy ได้ ทำได้แต่เว็บเล็กๆ นั่นเอง :)
สุดท้าย Source Code ของบทความนี้ครับ
- Authors
-
Chai Phonbopit
เป็น Web Dev ในบริษัทแห่งหนึ่ง ทำงานมา 10 ปีกว่าๆ ด้วยภาษาและเทคโนโลยี เช่น JavaScript, Node.js, React, Vue และปัจจุบันกำลังสนใจในเรื่องของ Blockchain และ Crypto กำลังหัดเรียนภาษา Rust