Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.
Amazon MQ untuk praktik terbaik ActiveMQ
Gunakan ini sebagai referensi untuk menemukan rekomendasi dengan cepat guna memaksimalkan performa dan meminimalkan biaya throughput saat bekerja dengan broker ActiveMQ di Amazon MQ.
Jangan Pernah Memodifikasi atau Menghapus Antarmuka Jaringan Elastis Amazon MQ
Saat pertama kali membuat broker Amazon MQ, Amazon MQ menyediakan antarmuka jaringan elastis di Virtual Private Cloud VPC () di bawah akun Anda dan, dengan demikian, memerlukan sejumlah izin. EC2 Antarmuka jaringan memungkinkan klien Anda (produsen atau konsumen) berkomunikasi dengan broker Amazon MQ. Antarmuka jaringan dianggap berada dalam lingkup layanan Amazon MQ, meskipun menjadi bagian dari akun Anda. VPC
Awas
Anda tidak harus memodifikasi atau menghapus antarmuka jaringan ini. Memodifikasi atau menghapus antarmuka jaringan dapat menyebabkan hilangnya koneksi permanen antara Anda VPC dan broker Anda.
Selalu Gunakan Pooling Koneksi
Dalam skenario dengan produsen tunggal dan konsumen tunggal (seperti tutorial Memulai: Membuat dan menghubungkan ke broker ActiveMQ), Anda dapat menggunakan satu kelas ActiveMQConnectionFactory
// Create a connection factory.
final ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory(wireLevelEndpoint);
// Pass the sign-in credentials.
connectionFactory.setUserName(activeMqUsername);
connectionFactory.setPassword(activeMqPassword);
// Establish a connection for the consumer.
final Connection consumerConnection = connectionFactory.createConnection();
consumerConnection.start();
Namun, dalam skenario yang lebih realistis dengan beberapa produsen dan konsumen, membuat sejumlah besar koneksi untuk beberapa produsen dapat menghabiskan banyak biaya. Dalam skenario ini, Anda harus mengelompokkan beberapa permintaan produsen menggunakan kelas PooledConnectionFactory
catatan
Konsumen pesan jangan pernah gunakan kelas PooledConnectionFactory
.
// Create a connection factory.
final ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory(wireLevelEndpoint);
// Pass the sign-in credentials.
connectionFactory.setUserName(activeMqUsername);
connectionFactory.setPassword(activeMqPassword);
// Create a pooled connection factory.
final PooledConnectionFactory pooledConnectionFactory = new PooledConnectionFactory();
pooledConnectionFactory.setConnectionFactory(connectionFactory);
pooledConnectionFactory.setMaxConnections(10);
// Establish a connection for the producer.
final Connection producerConnection = pooledConnectionFactory.createConnection();
producerConnection.start();
Selalu Gunakan Transportasi Failover untuk Terhubung ke Beberapa Titik Akhir Broker
Jika aplikasi Anda perlu terhubung ke beberapa titik akhir broker—misalnya, ketika Anda menggunakan mode deployment aktif/siaga atau saat Anda bermigrasi dari broker pesan on-premise ke Amazon MQ—gunakan Transportasi Failover
failover:(ssl://b-1234a5b6-78cd-901e-2fgh-3i45j6k178l9-1.mq.us-east-2.amazonaws.com:61617,ssl://b-9876l5k4-32ji-109h-8gfe-7d65c4b132a1-2.mq.us-east-2.amazonaws.com:61617)?randomize=true
Hindari Penggunaan Penyeleksi Pesan
Dimungkinkan untuk menggunakan JMSpemilih
Secara umum, buat agar konsumen tidak dapat merutekan pesan karena, untuk pemisahan yang optimal antara konsumen dan produsen, baik konsumen dan produsen harus bersifat sementara.
Memilih Tujuan Virtual untuk Langganan Tahan Lama
Langganan tahan lama
Jika menggunakan VPC peering Amazon, hindari klien IPs dalam jangkauan CIDR 10.0.0.0/16
Jika Anda menyiapkan VPC peering Amazon antara infrastruktur on-premise dan broker Amazon MQ Anda, Anda tidak boleh mengonfigurasi koneksi klien dengan jangkauan. IPs CIDR 10.0.0.0/16
Menonaktifkan Penyimpanan dan Pengiriman Bersamaan untuk Antrean dengan Konsumen Lambat
Secara default, Amazon MQ mengoptimalkan antrean dengan konsumen cepat:
-
Konsumen dianggap cepat jika mereka mampu bersaing dengan laju pesan yang dihasilkan oleh produsen.
-
Konsumen dianggap lambat jika antrean menimbulkan backlog pesan yang tidak diakui, berpotensi menyebabkan penurunan throughput produsen.
Untuk menginstruksikan Amazon MQ agar mengoptimalkan antrean dengan konsumen lambat, atur concurrentStoreAndDispatchQueues
atribut ke false
. Contoh konfigurasi, lihat concurrentStoreAndDispatchQueues.
Memilih Tipe Instans Broker yang Tepat untuk Throughput Terbaik
Throughput pesan dari tipe instans broker tergantung pada kasus penggunaan aplikasi Anda dan faktor berikut:
-
Penggunaan ActiveMQ dalam mode tetap
-
Ukuran pesan
-
Jumlah produsen dan konsumen
-
Jumlah tujuan
Memahami hubungan antara ukuran pesan, latensi, dan throughput
Tergantung pada kasus penggunaan Anda, tipe instans broker yang lebih besar mungkin tidak selalu meningkatkan throughput sistem. Ketika ActiveMQ menulis pesan ke penyimpanan tahan lama, ukuran pesan Anda menentukan faktor pembatas sistem:
-
Jika pesan Anda lebih kecil dari 100 KB, latensi penyimpanan tetap adalah faktor pembatas.
-
Jika pesan Anda lebih besar dari 100 KB, throughput penyimpanan tetap adalah faktor pembatas.
Ketika Anda menggunakan ActiveMQ dalam mode tetap, menulis ke penyimpanan biasanya terjadi ketika ada beberapa konsumen atau ketika konsumen lambat. Dalam modus tidak tetap, menulis ke penyimpanan juga terjadi dengan konsumen lambat jika memori tumpukan instans broker penuh.
Untuk menentukan tipe instans broker terbaik bagi aplikasi Anda, kami merekomendasikan pengujian tipe instans broker yang berbeda. Untuk informasi selengkapnya, lihat Broker instance types dan juga Mengukur Throughput untuk Amazon MQ menggunakan JMS
Kasus penggunaan untuk jenis instans broker yang lebih besar
Ada tiga kasus penggunaan umum ketika tipe instans broker yang lebih besar meningkatkan throughput:
-
Mode tidak tetap – Ketika aplikasi Anda kurang sensitif terhadap kehilangan pesan selama failover instans broker (misalnya, ketika menyiarkan skor olahraga), Anda mungkin sering menggunakan mode tidak tetap ActiveMQ. Dalam mode ini, ActiveMQ menulis pesan ke penyimpanan tetap hanya jika memori tumpukan instans broker penuh. Sistem yang menggunakan mode non-persisten dapat memperoleh manfaat dari jumlah memori yang lebih tinggi, jaringan yang lebih cepatCPU, dan lebih cepat yang tersedia pada jenis instans broker yang lebih besar.
-
Konsumen cepat – Ketika konsumen aktif tersedia dan bendera concurrentStoreAndDispatchQueues diaktifkan, ActiveMQ memungkinkan pesan mengalir langsung dari produsen ke konsumen tanpa mengirim pesan ke penyimpanan (bahkan dalam mode tetap). Jika aplikasi Anda dapat mengonsumsi pesan dengan cepat (atau jika Anda dapat merancang konsumen Anda untuk melakukan hal ini), aplikasi bisa mendapatkan keuntungan dari tipe instans broker yang lebih besar. Untuk membiarkan aplikasi Anda mengonsumsi pesan lebih cepat, tambahkan utas konsumen ke instans aplikasi Anda atau tingkatkan skala instans aplikasi Anda secara vertikal atau horizontal.
-
Transaksi yang di-batch – Ketika menggunakan mode tetap dan mengirim beberapa pesan per transaksi, Anda dapat mencapai throughput pesan yang lebih tinggi secara keseluruhan dengan menggunakan tipe instans broker yang lebih besar. Untuk informasi selengkapnya, lihat Should I Use Transactions?
dalam dokumentasi ActiveMQ.
Pilih jenis penyimpanan broker yang tepat untuk throughput terbaik
Untuk memanfaatkan daya tahan tinggi dan replikasi di beberapa Availability Zone, gunakan AmazonEFS. Untuk memanfaatkan latensi rendah dan throughput tinggi, gunakan Amazon. EBS Untuk informasi selengkapnya, lihat Storage.
Mengonfigurasi Jaringan Broker dengan Benar
Saat Anda membuat jaringan broker, konfigurasikan dengan benar untuk aplikasi Anda:
-
Aktifkan mode tetap – Karena (tergantung pada rekannya) setiap instans broker bertindak seperti produsen atau konsumen, jaringan broker tidak menyediakan replikasi terdistribusi dari pesan. Broker pertama yang bertindak sebagai konsumen menerima pesan dan menahannya ke penyimpanan. Broker ini mengirimkan pengakuan kepada produsen dan meneruskan pesan ke broker berikutnya. Ketika broker kedua mengakui ketetapan pesan, broker pertama akan menghapus pesan.
Jika modus tetap dinonaktifkan, broker pertama mengakui produsen tanpa menahan pesan ke penyimpanan. Untuk informasi selengkapnya, lihat Replicated Message Store
dan What is the difference between persistent and non-persistent delivery? dalam dokumentasi Apache ActiveMQ. -
Jangan nonaktifkan pesan penasihat untuk instans broker – Untuk informasi selengkapnya, lihat Advisory Message
dalam dokumentasi Apache ActiveMQ. -
Jangan gunakan penemuan broker multicast – Amazon MQ tidak mendukung penemuan broker menggunakan multicast. Untuk informasi selengkapnya, lihat What is the difference between discovery, multicast, and zeroconf?
dalam dokumentasi Apache ActiveMQ.
Hindari mulai ulang lambat dengan memulihkan transaksi XA yang disiapkan
ActiveMQ mendukung transaksi terdistribusi (XA). Mengetahui cara ActiveMQ memproses transaksi XA dapat membantu menghindari waktu pemulihan yang lambat untuk mulai ulang dan failover broker di Amazon MQ
Transaksi XA yang disiapkan dan belum terselesaikan akan diputar ulang pada setiap mulai ulang. Jika masih belum terselesaikan, jumlahnya akan bertambah dari waktu ke waktu, secara signifikan meningkatkan waktu yang dibutuhkan untuk memulai broker. Hal ini memengaruhi waktu mulai ulang dan failover. Anda harus menyelesaikan transaksi ini dengan commit()
atau rollback()
agar performa tidak menurun seiring waktu.
Untuk memantau transaksi XA yang belum terselesaikan, Anda dapat menggunakan JournalFilesForFastRecovery
metrik di Amazon CloudWatch Logs. Jika jumlah ini meningkat, atau secara konsisten lebih tinggi dari 1
, Anda harus memulihkan transaksi yang belum terselesaikan dengan kode yang serupa dengan contoh berikut. Untuk informasi selengkapnya, lihat Quotas in Amazon MQ.
Kode contoh berikut berjalan menelusuri transaksi XA yang disiapkan dan menutupnya dengan rollback()
.
import org.apache.activemq.ActiveMQXAConnectionFactory; import javax.jms.XAConnection; import javax.jms.XASession; import javax.transaction.xa.XAResource; import javax.transaction.xa.Xid; public class RecoverXaTransactions { private static final ActiveMQXAConnectionFactory ACTIVE_MQ_CONNECTION_FACTORY; final static String WIRE_LEVEL_ENDPOINT = "tcp://localhost:61616";; static { final String activeMqUsername = "
MyUsername123
"; final String activeMqPassword = "MyPassword456
"; ACTIVE_MQ_CONNECTION_FACTORY = new ActiveMQXAConnectionFactory(activeMqUsername, activeMqPassword, WIRE_LEVEL_ENDPOINT); ACTIVE_MQ_CONNECTION_FACTORY.setUserName(activeMqUsername); ACTIVE_MQ_CONNECTION_FACTORY.setPassword(activeMqPassword); } public static void main(String[] args) { try { final XAConnection connection = ACTIVE_MQ_CONNECTION_FACTORY.createXAConnection(); XASession xaSession = connection.createXASession(); XAResource xaRes = xaSession.getXAResource(); for (Xid id : xaRes.recover(XAResource.TMENDRSCAN)) { xaRes.rollback(id); } connection.close(); } catch (Exception e) { } } }
Dalam skenario dunia nyata, Anda dapat memeriksa transaksi XA yang disiapkan pada Manajer Transaksi XA. Kemudian Anda dapat memutuskan apakah akan menangani setiap transaksi yang disiapkan dengan rollback()
atau commit()
.