ssm整合kafka

1 配置文件配置kafka路径

#kafak地址
bootstrap.servers=xx.xxx.xx.xx:端口
#id(可以随便编一个,相当于身份证)
group.id=xxxxx

2 我这里选择配置文件注入



<!-- kafka-->
	<!--1.定义consumer的参数 -->
	<bean id="consumerProperties" class="java.util.HashMap">
		<constructor-arg>
			<map>

				<entry key="bootstrap.servers" value="${bootstrap.servers}" />
				<entry key="group.id" value="${group.id}" />
				<entry key="enable.auto.commit" value="${enable.auto.commit}" />
				<entry key="session.timeout.ms" value="${session.timeout.ms}" />
				<entry key="key.deserializer"
					   value="org.apache.kafka.common.serialization.StringDeserializer" />
				<entry key="value.deserializer"
					   value="org.apache.kafka.common.serialization.StringDeserializer" />
				<entry key="max.poll.interval.ms" value="300000 " />
				<entry key="max.poll.records" value="500 " />
				<entry key="session.time.out" value="10000 " />
				<entry key="heartbeat.interval.ms" value="3000 " />
			</map>
		</constructor-arg>
	</bean>

	<!-- 2.创建consumerFactory bean -->
	<bean id="consumerFactory"
		  class="org.springframework.kafka.core.DefaultKafkaConsumerFactory" >
		<constructor-arg>
			<ref bean="consumerProperties" />
		</constructor-arg>
	</bean>

	<!-- 3.定义消费实现类 -->
	<bean id="kafkaConsumerService" class="com.KafkaRepeater">
		<constructor-arg index="0" ref="这里可以注入你需要写入的实现类" />
	</bean>

	<!-- 4.消费者容器配置信息 -->
	<bean id="containerProperties" class="org.springframework.kafka.listener.config.ContainerProperties">
		<!-- topic -->
		<constructor-arg index="0">
			<list>
				<value>pppppppp</value>
			</list>
		</constructor-arg>
		<property name="messageListener" ref="kafkaConsumerService" />
	</bean>

	<!-- 5.消费者并发消息监听容器,执行doStart()方法 -->
	<bean id="messageListenerContainer" class="org.springframework.kafka.listener.ConcurrentMessageListenerContainer" init-method="doStart" >
		<constructor-arg ref="consumerFactory" />
		<constructor-arg ref="containerProperties" />
		<property name="concurrency" value="${concurrency}" />
	</bean>

<!--	kafka生产者-->
	<!-- 1.参数配置 -->
	<bean id="producerProperties" class="java.util.HashMap">
		<constructor-arg>
			<map>
				<entry key="bootstrap.servers" value="${bootstrap.servers}" />
				<!-- 组id标志 -->
				<entry key="group.id" value="${group.id}" />
				<entry key="retries" value="2" />
				<entry key="enable.idempotence" value="true" />
				<entry key="ack" value="all"/>
				<entry key="batch.size" value="1638" />
				<entry key="linger.ms" value="1" />
				<entry key="buffer.memory" value="33554432 " />
				<entry key="key.serializer"
					   value="org.apache.kafka.common.serialization.StringSerializer" />
				<entry key="value.serializer"
					   value="org.apache.kafka.common.serialization.StringSerializer" />
			</map>
		</constructor-arg>
	</bean>
	<!--  2.创建kafkatemplate需要使用的producerfactory bean  -->
	<bean id="producerFactory"
		  class="org.springframework.kafka.core.DefaultKafkaProducerFactory">
		<constructor-arg>
			<ref bean="producerProperties" />
		</constructor-arg>
	</bean>
	<!--    3.创建kafkatemplate bean,使用的时候,只需要注入这个bean,即可使用template的send消息方法-->
	<bean id="KafkaTemplate"
		  class="org.springframework.kafka.core.KafkaTemplate">
		<constructor-arg ref="producerFactory" />
		<!--设置对应topic -->
		<property name="defaultTopic" value="one1" />
	</bean>
	<!-- 3.定义消费实现类 -->
	<bean id="KafkaProducerService" class="com.KafkaProducer">
		<constructor-arg index="0" ref="这里可以注入你需要写入的实现类(我这里没应用,你可以注掉)" />
	</bean>

3 生产者

@Component
public class KafkaProducer {

    @Resource
    private KafkaTemplate kafkaTemplate;

//要发到哪个topic上
    public void sendJscf(String json) {
        if(json!=null) {
            kafkaTemplate.send("topic", json);
        }
    }

}

4 定义消费者

 
public class KafkaRepeater implements MessageListener<String, String> {



   @Override
    public void onMessage(ConsumerRecord<String, String> data) {
        if ("pppppppp".equals(data.topic())) {
            View limit = JSON.parseObject(data.value(), View.class);
          
        }
    }

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值