{"id":692,"date":"2024-06-20T23:39:43","date_gmt":"2024-06-21T02:39:43","guid":{"rendered":"http:\/\/www.isacaguiar.com.br\/blog\/?p=692"},"modified":"2024-06-13T00:53:56","modified_gmt":"2024-06-13T03:53:56","slug":"processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java","status":"publish","type":"post","link":"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/","title":{"rendered":"Processamento Paralelo de Mensagens com Oracle Advanced Queue e Java"},"content":{"rendered":"<h4>Introdu\u00e7\u00e3o<\/h4>\n<p>O gerenciamento eficiente de grandes volumes de dados \u00e9 crucial em sistemas de banco de dados. O Oracle Advanced Queue (AQ) oferece uma solu\u00e7\u00e3o robusta para processamento ass\u00edncrono e em paralelo de mensagens. Este artigo apresenta uma abordagem pr\u00e1tica para utilizar Oracle AQ em conjunto com threads em Java para processar registros de uma tabela particionada e subparticionada, onde o payload da mensagem \u00e9 um JSON.<\/p>\n<h4>Estrutura da Tabela<\/h4>\n<p>Vamos considerar uma tabela de pedidos (<code>orders<\/code>) particionada por uma fun\u00e7\u00e3o <code>MOD(256, id)<\/code> e subparticionada pelo dia do ano. A estrutura da tabela \u00e9 definida da seguinte maneira:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"wp-block-preformatted prism line-numbers lang-sql\" data-lang=\"XML\"><code class=\"language-xml\"><span class=\"hljs-tag\"><\/span><\/code><code class=\"language-sql\">CREATE TABLE orders (\r\n    order_id        NUMBER,\r\n    customer_id     NUMBER,\r\n    order_date      DATE,\r\n    amount          NUMBER,\r\n    partition_id    NUMBER GENERATED ALWAYS AS (MOD(order_id, 128)),\r\n    partition_day   NUMBER GENERATED ALWAYS AS (TO_NUMBER(TO_CHAR(order_date, 'DDD')))\r\n)\r\nPARTITION BY RANGE (partition_day)\r\nSUBPARTITION BY LIST (partition_id)\r\nSUBPARTITION TEMPLATE (\r\n  SUBPARTITION p000 VALUES (0),\r\n  SUBPARTITION p001 VALUES (1),\r\n  -- Continue at\u00e9 p127\r\n  SUBPARTITION p127 VALUES (127)\r\n)\r\n(\r\n  PARTITION d001 VALUES LESS THAN (2),\r\n  PARTITION d002 VALUES LESS THAN (3),\r\n  -- Continue at\u00e9 d365\r\n  PARTITION d365 VALUES LESS THAN (366)\r\n);\r\n<\/code><\/pre>\n<\/div>\n<h4>Configurando o Oracle Advanced Queue<\/h4>\n<p>Para gerenciar a fila, precisamos criar um tipo de mensagem JSON, uma tabela de filas e a fila propriamente dita.<\/p>\n<h5>Cria\u00e7\u00e3o da Fila<\/h5>\n<div class=\"hcb_wrap\">\n<pre class=\"wp-block-preformatted prism line-numbers lang-sql\" data-lang=\"SQL\"><code class=\"language-sql\">-- Conectar-se ao esquema apropriado\r\nCONNECT your_schema\/your_password;\r\n\r\n-- Criar um tipo de objeto para a mensagem\r\nCREATE OR REPLACE TYPE message_type AS OBJECT (\r\n    order_id NUMBER,\r\n    customer_id NUMBER,\r\n    order_date DATE,\r\n    amount NUMBER\r\n);\r\n\r\n-- Criar uma tabela de filas\r\nBEGIN\r\n    DBMS_AQADM.CREATE_QUEUE_TABLE(\r\n        queue_table        =&gt; 'order_queue_table',\r\n        queue_payload_type =&gt; 'message_type'\r\n    );\r\nEND;\r\n\/\r\n\r\n-- Criar a fila\r\nBEGIN\r\n    DBMS_AQADM.CREATE_QUEUE(\r\n        queue_name    =&gt; 'order_queue',\r\n        queue_table   =&gt; 'order_queue_table'\r\n    );\r\nEND;\r\n\/\r\n\r\n-- Iniciar a fila\r\nBEGIN\r\n    DBMS_AQADM.START_QUEUE(\r\n        queue_name =&gt; 'order_queue'\r\n    );\r\nEND;\r\n\/\r\n<\/code><\/pre>\n<\/div>\n<h3>Implementa\u00e7\u00e3o em Java com Spring<\/h3>\n<h4>Estrutura do Projeto<\/h4>\n<ol>\n<li><strong>Repository<\/strong>: Cont\u00e9m os m\u00e9todos de inser\u00e7\u00e3o e enfileiramento (enqueue) e de desenfileiramento (dequeue) de mensagens.<\/li>\n<li><strong>Service<\/strong>: Cont\u00e9m a l\u00f3gica de neg\u00f3cios para inserir pedidos e processar mensagens da fila.<\/li>\n<li><strong>Consumidor<\/strong>: Utiliza JMS com Spring para consumir mensagens da fila em threads paralelas.<\/li>\n<\/ol>\n<h5>Depend\u00eancias Maven<\/h5>\n<p>Certifique-se de adicionar as depend\u00eancias do Spring JMS e do Oracle JDBC ao seu <code>pom.xml<\/code>:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"wp-block-preformatted prism line-numbers lang-sql\" data-lang=\"XML\"><code class=\"language-xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">dependency<\/span>&gt;\r\n<\/span><span class=\"hljs-tag\">    &lt;<span class=\"hljs-name\">groupId<\/span>&gt;<\/span>org.springframework.boot<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">groupId<\/span>&gt;\r\n<\/span><span class=\"hljs-tag\">    &lt;<span class=\"hljs-name\">artifactId<\/span>&gt;<\/span>spring-boot-starter-data-jpa<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">artifactId<\/span>&gt;\r\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">dependency<\/span>&gt;\r\n<\/span><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">dependency<\/span>&gt;\r\n<\/span><span class=\"hljs-tag\">    &lt;<span class=\"hljs-name\">groupId<\/span>&gt;<\/span>org.springframework.boot<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">groupId<\/span>&gt;\r\n<\/span><span class=\"hljs-tag\">    &lt;<span class=\"hljs-name\">artifactId<\/span>&gt;<\/span>spring-boot-starter-jms<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">artifactId<\/span>&gt;\r\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">dependency<\/span>&gt;\r\n<\/span><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">dependency<\/span>&gt;\r\n<\/span><span class=\"hljs-tag\">    &lt;<span class=\"hljs-name\">groupId<\/span>&gt;<\/span>com.oracle.database.jdbc<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">groupId<\/span>&gt;\r\n<\/span><span class=\"hljs-tag\">    &lt;<span class=\"hljs-name\">artifactId<\/span>&gt;<\/span>ojdbc8<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">artifactId<\/span>&gt;\r\n<\/span><span class=\"hljs-tag\">    &lt;<span class=\"hljs-name\">version<\/span>&gt;<\/span>19.8.0.0<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">version<\/span>&gt;\r\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">dependency<\/span>&gt;<\/span><\/code><\/pre>\n<\/div>\n<h4>1. Classe Repository<\/h4>\n<p>A classe <code>OrderRepository<\/code> gerencia a intera\u00e7\u00e3o com o banco de dados.<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"wp-block-preformatted prism line-numbers lang-java\" data-lang=\"Java\"><code class=\"language-java\">import org.springframework.stereotype.Repository;\r\nimport javax.sql.DataSource;\r\nimport java.sql.*;\r\n\r\n@Repository\r\npublic class OrderRepository {\r\n    private final DataSource dataSource;\r\n\r\n    public OrderRepository(DataSource dataSource) {\r\n        this.dataSource = dataSource;\r\n    }\r\n\r\n    public void insertOrder(int orderId, int customerId, Date orderDate, double amount) throws SQLException {\r\n        String insertSQL = \"INSERT INTO orders (order_id, customer_id, order_date, amount) VALUES (?, ?, ?, ?)\";\r\n        try (Connection conn = dataSource.getConnection();\r\n             PreparedStatement stmt = conn.prepareStatement(insertSQL)) {\r\n            stmt.setInt(1, orderId);\r\n            stmt.setInt(2, customerId);\r\n            stmt.setDate(3, orderDate);\r\n            stmt.setDouble(4, amount);\r\n            stmt.executeUpdate();\r\n        }\r\n    }\r\n\r\n    public void enqueueMessage(int orderId, int customerId, Date orderDate, double amount) throws SQLException {\r\n        String jsonMessage = String.format(\"{\\\"order_id\\\": %d, \\\"customer_id\\\": %d, \\\"order_date\\\": \\\"%s\\\", \\\"amount\\\": %f}\", orderId, customerId, orderDate, amount);\r\n        String enqueueSQL = \"BEGIN \"\r\n                          + \"DBMS_AQ.ENQUEUE(:1, DBMS_AQ.ENQUEUE_OPTIONS_T(), DBMS_AQ.MESSAGE_PROPERTIES_T(), SYS.ANYDATA.ConvertVarchar2(:2), :3); \"\r\n                          + \"END;\";\r\n        try (Connection conn = dataSource.getConnection();\r\n             CallableStatement stmt = conn.prepareCall(enqueueSQL)) {\r\n            stmt.setString(1, \"order_queue\");\r\n            stmt.setString(2, jsonMessage);\r\n            stmt.registerOutParameter(3, Types.RAW);\r\n            stmt.execute();\r\n        }\r\n    }\r\n\r\n    public String dequeueMessage() throws SQLException {\r\n        String dequeueSQL = \"BEGIN \"\r\n                          + \"DBMS_AQ.DEQUEUE(:1, DBMS_AQ.DEQUEUE_OPTIONS_T(), DBMS_AQ.MESSAGE_PROPERTIES_T(), :2, :3); \"\r\n                          + \"END;\";\r\n        try (Connection conn = dataSource.getConnection();\r\n             CallableStatement stmt = conn.prepareCall(dequeueSQL)) {\r\n            stmt.setString(1, \"order_queue\");\r\n            stmt.registerOutParameter(2, Types.STRUCT, \"SYS.ANYDATA\");\r\n            stmt.registerOutParameter(3, Types.RAW);\r\n            stmt.execute();\r\n            return stmt.getString(2);\r\n        }\r\n    }\r\n}\r\n<\/code><\/pre>\n<\/div>\n<p><strong>Classe Repository<\/strong>:<\/p>\n<ul>\n<li><strong>insertOrder<\/strong>: Insere um pedido na tabela <code>orders<\/code>.<\/li>\n<li><strong>enqueueMessage<\/strong>: Enfileira uma mensagem JSON na fila Oracle AQ.<\/li>\n<li><strong>dequeueMessage<\/strong>: Desenfileira uma mensagem da fila Oracle AQ.<\/li>\n<\/ul>\n<h4>2. Classe Service<\/h4>\n<p>A classe <code>OrderService<\/code> utiliza o <code>OrderRepository<\/code> para inserir pedidos e processar mensagens.<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"wp-block-preformatted prism line-numbers lang-java\" data-lang=\"Java\"><code class=\"language-java\">import org.springframework.stereotype.Service;\r\nimport org.springframework.transaction.annotation.Transactional;\r\nimport java.sql.Date;\r\nimport java.sql.SQLException;\r\n\r\n@Service\r\npublic class OrderService {\r\n    private final OrderRepository repository;\r\n\r\n    public OrderService(OrderRepository repository) {\r\n        this.repository = repository;\r\n    }\r\n\r\n    @Transactional\r\n    public void insertOrder(int orderId, int customerId, Date orderDate, double amount) {\r\n        try {\r\n            repository.insertOrder(orderId, customerId, orderDate, amount);\r\n            repository.enqueueMessage(orderId, customerId, orderDate, amount);\r\n        } catch (SQLException e) {\r\n            e.printStackTrace();\r\n            throw new RuntimeException(e);\r\n        }\r\n    }\r\n\r\n    public void processMessage(String message) {\r\n        \/\/ Converter a mensagem JSON para um objeto Java\r\n        JSONObject jsonObject = new JSONObject(message);\r\n        int orderId = jsonObject.getInt(\"order_id\");\r\n        int customerId = jsonObject.getInt(\"customer_id\");\r\n        String orderDate = jsonObject.getString(\"order_date\");\r\n        double amount = jsonObject.getDouble(\"amount\");\r\n\r\n        \/\/ Processar a mensagem\r\n        System.out.println(\"Processing order ID: \" + orderId + \", Customer ID: \" + customerId);\r\n        \/\/ Adicionar a l\u00f3gica de processamento da mensagem aqui\r\n    }\r\n\r\n    public void processMessages() {\r\n        try {\r\n            while (true) {\r\n                String message = repository.dequeueMessage();\r\n                if (message != null) {\r\n                    System.out.println(\"Processing message: \" + message);\r\n                    \/\/ Adicionar l\u00f3gica de processamento de mensagens aqui\r\n                } else {\r\n                    System.out.println(\"No messages to process.\");\r\n                }\r\n            }\r\n        } catch (SQLException e) {\r\n            e.printStackTrace();\r\n        }\r\n    }\r\n}\r\n<\/code><\/pre>\n<\/div>\n<p><strong>Classe Service<\/strong>:<\/p>\n<ul>\n<li><strong>insertOrder<\/strong>: Usa o <code>OrderRepository<\/code> para inserir um pedido e enfileirar uma mensagem na fila.<\/li>\n<li><strong>processMessage<\/strong>: Converte a mensagem JSON para um objeto Java e realiza o processamento da mensagem.<\/li>\n<li><strong>processMessages<\/strong>: Processa mensagens da fila (manuelmente) usando o <code>OrderRepository<\/code>.<\/li>\n<\/ul>\n<h4>3. Configura\u00e7\u00e3o do JMS com Spring<\/h4>\n<h5>Configura\u00e7\u00e3o do Application.yml<\/h5>\n<p>Adicione a configura\u00e7\u00e3o do DataSource e do JMS no arquivo <code>application.yml<\/code>:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"wp-block-preformatted prism line-numbers lang-yml\" data-lang=\"YAML\"><code class=\"language-yaml\">spring:\r\n  datasource:\r\n    url: jdbc:oracle:thin:@\/\/hostname:port\/service_name\r\n    username: your_schema\r\n    password: your_password\r\n  jms:\r\n    listener:\r\n      concurrency: 5-10\r\n<span class=\"hljs-attr\">partition:\r\n<\/span>  <span class=\"hljs-attr\">id:<\/span> <span class=\"hljs-number\">1<\/span> <span class=\"hljs-comment\"># Defina o ID da parti\u00e7\u00e3o para este consumidor<\/span>\r\n<\/code><\/pre>\n<\/div>\n<h5>Classe de Configura\u00e7\u00e3o do JMS<\/h5>\n<div class=\"hcb_wrap\">\n<pre class=\"wp-block-preformatted prism line-numbers lang-java\" data-lang=\"Java\"><code class=\"language-java\">import org.springframework.context.annotation.Bean;\r\nimport org.springframework.context.annotation.Configuration;\r\nimport org.springframework.jms.annotation.EnableJms;\r\nimport org.springframework.jms.config.DefaultJmsListenerContainerFactory;\r\nimport org.springframework.jms.core.JmsTemplate;\r\nimport org.apache.activemq.ActiveMQConnectionFactory;\r\n\r\n@Configuration\r\n@EnableJms\r\npublic class JmsConfig {\r\n    @Bean\r\n    public ActiveMQConnectionFactory connectionFactory() {\r\n        return new ActiveMQConnectionFactory(\"tcp:\/\/localhost:61616\");\r\n    }\r\n\r\n    @Bean\r\n    public DefaultJmsListenerContainerFactory jmsListenerContainerFactory() {\r\n        DefaultJmsListenerContainerFactory factory = new DefaultJmsListenerContainerFactory();\r\n        factory.setConnectionFactory(connectionFactory());\r\n        factory.setConcurrency(\"5-10\");\r\n        return factory;\r\n    }\r\n\r\n    @Bean\r\n    public JmsTemplate jmsTemplate() {\r\n        return new JmsTemplate(connectionFactory());\r\n    }\r\n}\r\n<\/code><\/pre>\n<\/div>\n<h3>Explica\u00e7\u00e3o dos Componentes<\/h3>\n<ol>\n<li><strong><code>ActiveMQConnectionFactory<\/code><\/strong>:\n<ul>\n<li><strong>BrokerURL<\/strong>: Define a URL do broker JMS. Aqui estamos usando ActiveMQ rodando localmente na porta padr\u00e3o <code>61616<\/code>.<\/li>\n<li><strong>UserName e Password<\/strong>: Credenciais para conex\u00e3o com o broker.<\/li>\n<\/ul>\n<\/li>\n<li><strong><code>DefaultJmsListenerContainerFactory<\/code><\/strong>:\n<ul>\n<li><strong>ConnectionFactory<\/strong>: Configura a f\u00e1brica de conex\u00f5es para o listener.<\/li>\n<li><strong>Concurrency<\/strong>: Define o n\u00edvel de concorr\u00eancia para o listener, especificando o n\u00famero m\u00ednimo e m\u00e1ximo de threads (<code>\"5-10\"<\/code>).<\/li>\n<li><strong>SessionAcknowledgeMode<\/strong>: Define o modo de confirma\u00e7\u00e3o de sess\u00e3o, aqui configurado para <code>CLIENT_ACKNOWLEDGE<\/code>, onde o consumidor confirma explicitamente a mensagem ap\u00f3s o processamento.<\/li>\n<\/ul>\n<\/li>\n<li><strong><code>JmsTemplate<\/code><\/strong>:\n<ul>\n<li>Utilizado para enviar mensagens ao broker JMS.<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<h5>Classe JMSConsumer<\/h5>\n<p>Vamos implementar a classe <code>JMSConsumer<\/code> usando o Spring JMS. O componente <code>JMSConsumer<\/code> usa a anota\u00e7\u00e3o <code>@JmsListener<\/code> para receber e processar mensagens da fila. Com a configura\u00e7\u00e3o de concorr\u00eancia definida, v\u00e1rias threads podem processar mensagens em paralelo.<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"wp-block-preformatted prism line-numbers lang-java\" data-lang=\"Java\"><code class=\"language-java\">import org.springframework.beans.factory.annotation.Autowired;\r\nimport org.springframework.jms.annotation.JmsListener;\r\nimport org.springframework.stereotype.Component;\r\n\r\n@Component\r\npublic class JMSConsumer {\r\n\r\n    private final OrderService orderService;\r\n    <span class=\"hljs-keyword\">private<\/span> <span class=\"hljs-keyword\">final<\/span> <span class=\"hljs-type\">int<\/span> partitionId;\r\n\r\n    @Autowired\r\n    public JMSConsumer(OrderService orderService, <span class=\"hljs-meta\">@Value(\"${partition.id}\")<\/span> <span class=\"hljs-type\">int<\/span> partitionId) {\r\n        this.orderService = orderService;\r\n<span class=\"hljs-built_in\">        this<\/span>.partitionId = partitionId;\r\n    }\r\n\r\n    @JmsListener(destination = \"order_queue\", containerFactory = \"jmsListenerContainerFactory\")\r\n    public void receiveMessage(String message) {\r\n        \/\/ Delegar o processamento da mensagem para o OrderService\r\n        System.out.println(\"Received message: \" + message);\r\n        orderService.processMessage(message);\r\n    }\r\n}\r\n<\/code><\/pre>\n<\/div>\n<p><strong>Configura\u00e7\u00e3o do JMS com Spring<\/strong>:<\/p>\n<ul>\n<li><strong>Application.yml<\/strong>: Define a configura\u00e7\u00e3o do DataSource e do JMS.<\/li>\n<li><strong>JmsConfig<\/strong>: Configura a f\u00e1brica de conex\u00f5es JMS e o template JMS.<\/li>\n<li><strong>JMSConsumer<\/strong>: Utiliza o Spring JMS Listener para consumir mensagens da fila e process\u00e1-las.\n<ul>\n<li><strong>@JmsListener<\/strong>: Configura o m\u00e9todo <code>receiveMessage<\/code> para escutar a fila <code>order_queue<\/code>. A f\u00e1brica de listeners <code>jmsListenerContainerFactory<\/code> \u00e9 utilizada para permitir o processamento paralelo.<\/li>\n<li><strong>receiveMessage<\/strong>: Recebe a mensagem e delega o processamento para o m\u00e9todo <code>processMessage<\/code> do <code>OrderService<\/code>.<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<h3>Conclus\u00e3o<\/h3>\n<p>Integrar Oracle Advanced Queuing com Spring JMS permite o processamento paralelo eficiente de mensagens, garantindo escalabilidade e desempenho na gest\u00e3o de grandes volumes de dados. Utilizando particionamento e filas particionadas, voc\u00ea pode minimizar a concorr\u00eancia e garantir que diferentes consumidores processam diferentes conjuntos de mensagens. Com a configura\u00e7\u00e3o do JMS e Spring, o sistema fica mais robusto e modular, facilitando a manuten\u00e7\u00e3o e a escalabilidade. Esta abordagem permite tamb\u00e9m que consumidores sejam configurados para processar mensagens de parti\u00e7\u00f5es espec\u00edficas, aumentando ainda mais a efici\u00eancia.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Introdu\u00e7\u00e3o O gerenciamento eficiente de grandes volumes de dados \u00e9 crucial em sistemas de banco de dados. O Oracle Advanced Queue (AQ)\u2026<\/p>\n","protected":false},"author":1,"featured_media":695,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[7,18,13,17],"tags":[],"class_list":["post-692","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-bd","category-desenvolvimento-de-software","category-java","category-oracle"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.2 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>Processamento Paralelo de Mensagens com Oracle Advanced Queue e Java - Blog do Aguiar<\/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.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/\" \/>\n<meta property=\"og:locale\" content=\"pt_BR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Processamento Paralelo de Mensagens com Oracle Advanced Queue e Java - Blog do Aguiar\" \/>\n<meta property=\"og:description\" content=\"Introdu\u00e7\u00e3o O gerenciamento eficiente de grandes volumes de dados \u00e9 crucial em sistemas de banco de dados. O Oracle Advanced Queue (AQ)\u2026\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog do Aguiar\" \/>\n<meta property=\"article:publisher\" content=\"https:\/\/www.facebook.com\/isac.velozo.aguiar\" \/>\n<meta property=\"article:published_time\" content=\"2024-06-21T02:39:43+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-12-23.06.59-An-image-for-an-article-titled-Processamento-Paralelo-de-Mensagens-com-Oracle-Advanced-Queue-e-Java.-The-image-features-a-professional-depiction-of-.webp\" \/>\n\t<meta property=\"og:image:width\" content=\"1024\" \/>\n\t<meta property=\"og:image:height\" content=\"1024\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/webp\" \/>\n<meta name=\"author\" content=\"isacaguiar\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Escrito por\" \/>\n\t<meta name=\"twitter:data1\" content=\"isacaguiar\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. tempo de leitura\" \/>\n\t<meta name=\"twitter:data2\" content=\"7 minutos\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/\"},\"author\":{\"name\":\"isacaguiar\",\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/#\/schema\/person\/78719359439f068d8b1e5e0bcb9d934d\"},\"headline\":\"Processamento Paralelo de Mensagens com Oracle Advanced Queue e Java\",\"datePublished\":\"2024-06-21T02:39:43+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/\"},\"wordCount\":632,\"image\":{\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-12-23.06.59-An-image-for-an-article-titled-Processamento-Paralelo-de-Mensagens-com-Oracle-Advanced-Queue-e-Java.-The-image-features-a-professional-depiction-of-.webp\",\"articleSection\":[\"Banco de Dados\",\"Desenvolvimento de Software\",\"Java\",\"Oracle\"],\"inLanguage\":\"pt-BR\"},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/\",\"url\":\"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/\",\"name\":\"Processamento Paralelo de Mensagens com Oracle Advanced Queue e Java - Blog do Aguiar\",\"isPartOf\":{\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/#primaryimage\"},\"image\":{\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-12-23.06.59-An-image-for-an-article-titled-Processamento-Paralelo-de-Mensagens-com-Oracle-Advanced-Queue-e-Java.-The-image-features-a-professional-depiction-of-.webp\",\"datePublished\":\"2024-06-21T02:39:43+00:00\",\"author\":{\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/#\/schema\/person\/78719359439f068d8b1e5e0bcb9d934d\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/#breadcrumb\"},\"inLanguage\":\"pt-BR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/#primaryimage\",\"url\":\"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-12-23.06.59-An-image-for-an-article-titled-Processamento-Paralelo-de-Mensagens-com-Oracle-Advanced-Queue-e-Java.-The-image-features-a-professional-depiction-of-.webp\",\"contentUrl\":\"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-12-23.06.59-An-image-for-an-article-titled-Processamento-Paralelo-de-Mensagens-com-Oracle-Advanced-Queue-e-Java.-The-image-features-a-professional-depiction-of-.webp\",\"width\":1024,\"height\":1024},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"In\u00edcio\",\"item\":\"http:\/\/www.isacaguiar.com.br\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Processamento Paralelo de Mensagens com Oracle Advanced Queue e Java\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/#website\",\"url\":\"https:\/\/www.isacaguiar.com.br\/blog\/\",\"name\":\"Blog do Aguiar\",\"description\":\"\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.isacaguiar.com.br\/blog\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"pt-BR\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/#\/schema\/person\/78719359439f068d8b1e5e0bcb9d934d\",\"name\":\"isacaguiar\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\/\/secure.gravatar.com\/avatar\/e22bb054d1154f07e6c91b82f0d68a219b6b04b58e5e3692c30cf457b51a9e9f?s=96&d=mm&r=g\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/e22bb054d1154f07e6c91b82f0d68a219b6b04b58e5e3692c30cf457b51a9e9f?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/e22bb054d1154f07e6c91b82f0d68a219b6b04b58e5e3692c30cf457b51a9e9f?s=96&d=mm&r=g\",\"caption\":\"isacaguiar\"},\"url\":\"https:\/\/www.isacaguiar.com.br\/blog\/author\/isacaguiar\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Processamento Paralelo de Mensagens com Oracle Advanced Queue e Java - Blog do Aguiar","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.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/","og_locale":"pt_BR","og_type":"article","og_title":"Processamento Paralelo de Mensagens com Oracle Advanced Queue e Java - Blog do Aguiar","og_description":"Introdu\u00e7\u00e3o O gerenciamento eficiente de grandes volumes de dados \u00e9 crucial em sistemas de banco de dados. O Oracle Advanced Queue (AQ)\u2026","og_url":"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/","og_site_name":"Blog do Aguiar","article_publisher":"https:\/\/www.facebook.com\/isac.velozo.aguiar","article_published_time":"2024-06-21T02:39:43+00:00","og_image":[{"width":1024,"height":1024,"url":"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-12-23.06.59-An-image-for-an-article-titled-Processamento-Paralelo-de-Mensagens-com-Oracle-Advanced-Queue-e-Java.-The-image-features-a-professional-depiction-of-.webp","type":"image\/webp"}],"author":"isacaguiar","twitter_card":"summary_large_image","twitter_misc":{"Escrito por":"isacaguiar","Est. tempo de leitura":"7 minutos"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/#article","isPartOf":{"@id":"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/"},"author":{"name":"isacaguiar","@id":"https:\/\/www.isacaguiar.com.br\/blog\/#\/schema\/person\/78719359439f068d8b1e5e0bcb9d934d"},"headline":"Processamento Paralelo de Mensagens com Oracle Advanced Queue e Java","datePublished":"2024-06-21T02:39:43+00:00","mainEntityOfPage":{"@id":"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/"},"wordCount":632,"image":{"@id":"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/#primaryimage"},"thumbnailUrl":"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-12-23.06.59-An-image-for-an-article-titled-Processamento-Paralelo-de-Mensagens-com-Oracle-Advanced-Queue-e-Java.-The-image-features-a-professional-depiction-of-.webp","articleSection":["Banco de Dados","Desenvolvimento de Software","Java","Oracle"],"inLanguage":"pt-BR"},{"@type":"WebPage","@id":"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/","url":"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/","name":"Processamento Paralelo de Mensagens com Oracle Advanced Queue e Java - Blog do Aguiar","isPartOf":{"@id":"https:\/\/www.isacaguiar.com.br\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/#primaryimage"},"image":{"@id":"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/#primaryimage"},"thumbnailUrl":"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-12-23.06.59-An-image-for-an-article-titled-Processamento-Paralelo-de-Mensagens-com-Oracle-Advanced-Queue-e-Java.-The-image-features-a-professional-depiction-of-.webp","datePublished":"2024-06-21T02:39:43+00:00","author":{"@id":"https:\/\/www.isacaguiar.com.br\/blog\/#\/schema\/person\/78719359439f068d8b1e5e0bcb9d934d"},"breadcrumb":{"@id":"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/#breadcrumb"},"inLanguage":"pt-BR","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/"]}]},{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/#primaryimage","url":"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-12-23.06.59-An-image-for-an-article-titled-Processamento-Paralelo-de-Mensagens-com-Oracle-Advanced-Queue-e-Java.-The-image-features-a-professional-depiction-of-.webp","contentUrl":"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-12-23.06.59-An-image-for-an-article-titled-Processamento-Paralelo-de-Mensagens-com-Oracle-Advanced-Queue-e-Java.-The-image-features-a-professional-depiction-of-.webp","width":1024,"height":1024},{"@type":"BreadcrumbList","@id":"https:\/\/www.isacaguiar.com.br\/blog\/processamento-paralelo-de-mensagens-com-oracle-advanced-queue-e-java\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"In\u00edcio","item":"http:\/\/www.isacaguiar.com.br\/blog\/"},{"@type":"ListItem","position":2,"name":"Processamento Paralelo de Mensagens com Oracle Advanced Queue e Java"}]},{"@type":"WebSite","@id":"https:\/\/www.isacaguiar.com.br\/blog\/#website","url":"https:\/\/www.isacaguiar.com.br\/blog\/","name":"Blog do Aguiar","description":"","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.isacaguiar.com.br\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"pt-BR"},{"@type":"Person","@id":"https:\/\/www.isacaguiar.com.br\/blog\/#\/schema\/person\/78719359439f068d8b1e5e0bcb9d934d","name":"isacaguiar","image":{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/secure.gravatar.com\/avatar\/e22bb054d1154f07e6c91b82f0d68a219b6b04b58e5e3692c30cf457b51a9e9f?s=96&d=mm&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/e22bb054d1154f07e6c91b82f0d68a219b6b04b58e5e3692c30cf457b51a9e9f?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/e22bb054d1154f07e6c91b82f0d68a219b6b04b58e5e3692c30cf457b51a9e9f?s=96&d=mm&r=g","caption":"isacaguiar"},"url":"https:\/\/www.isacaguiar.com.br\/blog\/author\/isacaguiar\/"}]}},"amp_enabled":true,"_links":{"self":[{"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/posts\/692","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/comments?post=692"}],"version-history":[{"count":6,"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/posts\/692\/revisions"}],"predecessor-version":[{"id":699,"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/posts\/692\/revisions\/699"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/media\/695"}],"wp:attachment":[{"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/media?parent=692"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/categories?post=692"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/tags?post=692"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}