How to integrate Kafka with Nginx

王林
Release: 2023-05-21 12:07:06
forward
2186 people have browsed it

Background

nginx-kafka-module is a plug-in for nginx. It can integrate kafka into nginx to facilitate the collection of front-end page buried point data in web projects. If the front-end page has set buried points, that is Some of the user's access and request data can be sent directly to the message middleware kafka through http requests. The backend can consume the messages in kafka through the program to perform real-time calculations. For example, sparkstream is used to consume data in Kafka in real time to analyze user pv, uv, some user behaviors and the funnel model conversion rate of the page, so as to better optimize the system or conduct real-time dynamic analysis of visiting users.

Specific integration steps

1. Install git

yum install -y git
Copy after login

2. Switch to the /usr/local/src directory, and then clone the kafka c client source code Go to local

cd /usr/local/src
git clone https://github.com/edenhill/librdkafka
Copy after login

3. Enter librdkafka, and then compile it

cd librdkafka
yum install -y gcc gcc-c++ pcre-devel zlib-devel
./configure
make && make install
Copy after login

4. Install nginx integration kafka plug-in, enter /usr/local/src, clone nginx integrates the source code of kafka

cd /usr/local/src
git clone https://github.com/brg-liuwei/ngx_kafka_module
Copy after login

5. Enter the nginx source package directory (compile nginx, and then compile the plug-in at the same time)

cd /usr/local/src/nginx-1.12.2
./configure --add-module=/usr/local/src/ngx_kafka_module/
make && make install
Copy after login

6. Modify nginx Configuration file: Set a location and kafaka topic

#添加配置(2处)
kafka;
kafka_broker_list f1:9092 f2:9092 f3:9092;

location = /kafka/access {
kafka_topic access888;
}
Copy after login

as shown below:

How to integrate Kafka with Nginx

How to integrate Kafka with Nginx

7. Start zk and kafka clusters (create topic)

zkserver.sh start
kafka-server-start.sh -daemon config/server.properties
Copy after login

8. Start nginx and report an error. The file kafka.so.1 cannot be found

error while loading shared libraries: librdkafka.so.1: cannot open shared object file: no such file or directory

##9. Loading so library


#开机加载/usr/local/lib下面的库
echo "/usr/local/lib" >> /etc/ld.so.conf
#手动加载
ldconfig
Copy after login

10. Test, write data to nginx, and then observe whether the kafka consumer can consume the data


curl http://localhost/kafka/access -d "message send to kafka topic"
curl http://localhost/kafka/access -d "小伟666"测试
Copy after login
You can also simulate the page buried request interface to send information:

How to integrate Kafka with Nginx

The background kafka consumption information is as shown in the figure:

How to integrate Kafka with Nginx

The above is the detailed content of How to integrate Kafka with Nginx. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:yisu.com
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template