Sử dụng pm2 để quản lý ứng dụng viết bằng Node.js

Sử dụng pm2 để quản lý ứng dụng viết bằng Node.js

Những mẩu tin ngắn hàng ngày dành cho bạn
  • Mọi người đã nghe nói đến Jujutsu - jj - một dạng quản lý phiên bản cho mã nguồn (version control system) chưa? Có vẻ như nó đang nhận được nhiều sự quan tâm.

    Chờ xíu! Chẳng phải git đã quá tốt rồi sao? Thế thì chế ra thằng jj để làm gì nữa? Cũng hơi khó trả lời nhỉ? Mỗi công cụ sinh ra chắc chắn phải cải thiện hoặc khắc phục được nhược điểm của cái trước. Cho nên jj ắt hẳn phải làm được điều gì đó mà git chưa làm được nên mới nổi lên như vậy.

    Thật ra mình đã nghe nói đến jj từ vài tháng trước rồi, nhưng vào đọc thì toàn kiến thức cao siêu. Hoặc là đang mang nặng cái lối suy nghĩ của git vào trong đầu rồi nên chưa lĩnh hội ra được điều gì cả.

    Mình hay có kiểu cái gì đọc lần 1 mà không hiểu thì đọc tiếp lần 2, lần 2 không hiểu thì đọc tiếp lần 3... đến lần thứ n mà vẫn không hiểu thì bỏ. Cơ mà không phải là từ bỏ mà một thời gian sau đó quay lại đọc tiếp. Đến một lúc nào đó khả năng mình sẽ hiểu ra một ít vấn đề, thế mới tài 😆.

    Thì cái jj này có vẻ như nó đang mở ra được tính linh hoạt trong việc "cam kết" mã. Tưởng tượng bạn đang làm việc trên một dự án, đang ở nhánh này, muốn sang nhánh khác để sửa, nhưng mà lại đang viết dở ở nhánh này, thế là phải stash, rồi checkout, rồi commit, rồi merge hoặc rebase lại vào nhánh cũ... nhìn chung quá trình làm việc với git nghiêm ngặt đến mức cứng nhắc, cần nhiều thao tác để giải quyết một vấn đề, chưa kể cái cây commit (commit-tree) nữa thì ôi thôi, khỏi xem cho đỡ nhức mắt. Thế nên ông jj này đang làm cách nào đó để bạn khỏi cần phải quan tâm đến các nhánh luôn, sửa trực tiếp vào commit. Nghe ảo nhỉ 😂.

    Đấy mới lĩnh hội được đến đấy, hy vọng sau n lần đọc lại nữa mình sẽ viết được một bài chi tiết hơn về công cụ này.

    » Xem thêm
  • Gòi gòi tới công chiện gòi 🤤🤤🤤

    » Xem thêm
  • Không biết blog được dẫn nguồn từ trang cà phê nào hay sao mà vài ba hôm trở lại đây thấy nhiều người tìm kiếm cà phê thế không biết 🤔.

    Tìm cả cách pha với tìm cả loại hạt, khổ nỗi họ tìm lại không ra bài viết nào vì mình chưa có viết đến mấy trường hợp đó. Phải chăng là ý trời 😀🙏

    » Xem thêm

Vấn đề

Khi mới tiếp xúc với Node.js và cũng là lần đầu học cách sử dụng Linux, nodemon là một thư viện mà tôi thường hay sử dụng để phát triển ứng dụng, vì chỉ cần lưu mã thì ngay lập tức nó sẽ "nạp" lại mã mới mà không cần phải "kill" đi bật lại ứng dụng một cách thủ công nữa, tính năng này ngày nay còn được gọi là "hot reload".

Sau bước phát triển là bước triển khai. Trong lúc thực hành chạy ứng dụng ở trên máy chủ, loay hoay mãi không biết làm sao để chạy được nó. Nếu dùng cách thông thường là gõ "node index.js" hoặc thậm chí dùng cả nodemon thì cứ mỗi khi thoát khỏi terminal, thoát khỏi máy chủ, thì ứng dụng cũng "bay màu" theo mất. Tôi hiểu rằng ứng dụng sẽ bị thoát nếu như không giữ được kết nối đến máy chủ. Thế là sao?

Mãi sau mới biết thì ra để giữ cho ứng dụng được chạy mãi, chúng ta cần phải có một công cụ quản lý tiến trình. Không chỉ cho riêng Node mà hầu hết các ngôn ngữ khác cũng cần phải có. Đối với Node thì cái tên được nhắc đến nhiều nhất có lẽ là pm2.

Từ khi biết đến pm2, tôi đã có thể dễ dàng triển khai các ứng dụng của mình. Cứ thế cho đến một thời gian sau, được làm nhiều dự án và tiếp xúc với nhiều công nghệ khác như Docker, Kubernetes... thì pm2 dần trở nên không còn cần thiết nữa, vì về bản chất các công cụ đó đã tích hợp sẵn công cụ dành cho quản lý.

Gần đây, khi đang bảo trì nhiều dự án, mà hầu hết chúng đều dùng pm2 thì tôi phải dành thời gian đọc lại tài liệu về cách sử dụng vì đã lâu rồi chưa đụng đến. Lúc đó chợt nhận ra đã có quá nhiều thay đổi trong khoảng thời gian đó. Nhiều tính năng mới được thêm vào hoặc cũng có thể là những tính năng mà mình chưa được biết đến.

Nhưng phải thành thật mà nói rằng pm2 vẫn là công cụ quản lý ứng dụng Node.js rất mạnh mẽ. Bất kỳ ai làm việc với Node cũng nên dành thời gian để tìm hiểu về nó. Vì thế bài viết ngày hôm nay tôi sẽ điểm lại một vài tính năng chính của công cụ này.

PM2 là gì?

pm2 là trình quản lý tiến trình daemon giúp bạn quản lý và duy trì ứng dụng luôn luôn trực tuyến.

Cài đặt pm2 rất đơn giản, thông qua npm tích hợp sẵn trong Node.

$ npm install pm2@latest -g

Sau đó bạn đã có thể khởi động ứng dụng Node của mình:

$ pm2 start app.js

Ứng dụng được chạy trong nền, để xem tất cả ứng dụng đang chạy:

$ pm2 list

Điều hữu ích nhất ở pm2 là nó giữ được ứng dụng chạy ở dưới nền, nghĩa là bạn có thoát khỏi máy chủ thì ứng dụng của bạn vẫn chạy.

Hầu hết mọi người đều biết khi chạy một ứng dụng Node, nó chỉ chạy trên một lõi của CPU. Nếu máy tính đa nhân thì Cluster mode sẽ giúp dàn trải tất cả tiến trình đến các lõi còn lại. Ví dụ CPU có 4 lõi, bạn muốn chạy trên cả 4 thì rất đơn giản.

$ pm2 start app.js -i max

max là chỉ định tất cả nhân đều tham gia, ngoài ra nếu muốn chính xác bao nhiêu thì thay max bằng một con số.

pm2 có cơ chế ghi logs vào tệp để truy xuất thông tin sau này. Các thông tin đó bao gồm các lệnh in vào console như console.log. Để xem lại logs:

$ pm2 logs 0

Với 0 là id của tiến trình hoặc thay nó bằng tên của tiến trình.

Để dừng một tiến trình:

$ pm2 stop 0

Chạy lại sau khi dừng:

$ pm2 start 0

Hoặc khởi động lại:

$ pm2 restart 0

Hoặc xoá hẳn ứng dụng với điều kiện nó phải được cho dừng từ trước:

$ pm2 delete 0

Các lệnh pm2 start là rời rạc và đơn lẻ. Tưởng tượng thay vì có một mà là có nhiều tiến trình Node cần khởi động cùng một lúc thì sao? Đó là lúc ecosystem trở nên hữu ích. ecosystem là cơ chế gom tất cả ứng dụng vào một tệp cấu hình và khởi động trong một lệnh duy nhất.

Để tạo một tệp cấu hình, sử dụng lệnh pm2 ecosystem, pm2 tạo ra một tệp ecosystem.config.js giống như sau:

module.exports = {
  apps : [{
    name: "app",
    script: "./app.js",
    env: {
      NODE_ENV: "development",
    },
    env_production: {
      NODE_ENV: "production",
    }
  }, {
     name: 'worker',
     script: 'worker.js'
  }]
}

Hãy sửa lại cấu hình cho phù hợp với dự án rồi khởi động nó bằng cách:

$ pm2 start ecosystem.config.js

Trong trường hợp máy chủ khởi động lại, pm2 không tự động khởi động theo khiến cho tất cả ứng dụng không hoạt động. Để giải quyết vấn đề này, sử dụng lệnh:

$ pm2 startup

Nhưng trước đó, bạn cần "commit" các tiến trình sẽ khởi động theo startup bằng lệnh:

$ pm2 save

pm2 save tạo ra một "snapshot" các tiến trình đang chạy tại thời điểm hiện tại để phục hồi lại tất cả sau này.

PM2 nâng cao

Pm2 có một số tính năng nâng cao tương đối hữu ích trong một số trường hợp.

RPC Function hoạt động theo kiểu chạy một hàm thông qua dòng lệnh. Ví dụ có một hàm countActive trả về số người đang trực tuyến thời điểm hiện tại.

Trước tiên, tạo một tệp rpc.js có nội dung:

const tx2 = require('tx2');

tx2.action('countActive', (reply) => {
  const num = UserModel.count();
  reply({ num: num });
})

setInterval(function() {
  // Keep application online
}, 100);

Khởi chạy:

$ pm2 start rpc.js

Sau đó nếu muốn kích hoạt hàm countActive thì chỉ cần:

pm2 trigger rpc countActive

Pm2 cũng cung cấp một API để quản lý pm2 thông qua RESTFul API. Hiểu đơn giản tức là bạn có thể tạo ra một máy chủ để thêm/sửa/xoá các ứng dụng khác dùng pm2, thực hiện qua việc gọi API. Bạn đọc có thể xem chi tiết tại PM2 API.

Và một vài tính năng nâng cao khác nữa.

pm2 plus

Gần đây, pm2 còn ra thêm dịch vụ pm2 plus cho phép giám sát ứng dụng một cách toàn diện như giao diện giám sát thời gian thực, báo cáo, nhật ký, và cả notifications... Có thể thấy nó khá tương đồng với các ứng dụng APM (Application Performance Monitoring). Nhưng vì không có gói miễn phí nên tôi chưa có dịp trải nghiệm dịch vụ này. Nếu bạn đã hoặc đang sử dụng, hãy để lại bình luận ở phía dưới bài viết nhé!

Cao cấp
Hello

5 bài học sâu sắc

Mỗi sản phẩm đi kèm với những câu chuyện. Thành công của người khác là nguồn cảm hứng cho nhiều người theo sau. 5 bài học rút ra được đã thay đổi con người tôi mãi mãi. Còn bạn? Hãy bấm vào ngay!

Mỗi sản phẩm đi kèm với những câu chuyện. Thành công của người khác là nguồn cảm hứng cho nhiều người theo sau. 5 bài học rút ra được đã thay đổi con người tôi mãi mãi. Còn bạn? Hãy bấm vào ngay!

Xem tất cả

Đăng ký nhận thông báo bài viết mới

hoặc
* Bản tin tổng hợp được gửi mỗi 1-2 tuần, huỷ bất cứ lúc nào.

Bình luận (0)

Nội dung bình luận...
Bấm hoặc cuộn mạnh để sang bài mới