`

post,get请求nginx记录日志kafka自动扫描程序

    博客分类:
  • java
 
阅读更多



        kafka的介绍以及使用安装请查看博文http://blog.csdn.net/hmsiwtv/article/details/46960053

讲的很详细,基本一看就会,这边主要介绍一下nginx记录日志kafka扫描

    一  nginx主要配置

 

log_format ht-video  '$request|$msec|$http_x_forwarded_for|$http_user_agent|$request_body';
	server{
                server_name 192.168.50.42;

                location / {
                        root html;
                        index index.html;
                }
                location /ht{
                        #root   html;
                        #index  index.html index.htm;
                        if ( $request ~ "GET" ) {
                                #access_log logs/test.log tes;
                                access_log /htlog/test.log test;
                        }

                        client_max_body_size 8000M;
                        #error_page 405 =200 $1;
                }
        }

 然后可以发送get请求  http://192.168.50.42:8080/ht/p?data=11211111111

注意在nginx的html目录下边需要有ht目录 然后目录下边需要建一个p文件,里面随便输点内容,是为了能请求到对应的文件

 

二 修改Kafka文件


vi /usr/local/kafka_2.11-0.9.0.1/config/server.properties
   这个文件里要改下面5点:
broker.id=0
port=9092
host.name=192.168.50.42

log.dirs=/log
zookeeper.connect=192.168.50.42:2181

 

三、启动zookeeper和kafka


/usr/local/kafka_2.11-0.9.0.1/bin/zookeeper-server-start.sh -daemon /usr/local/kafka_2.11-0.9.0.1/config/zookeeper.properties
/usr/local/kafka_2.11-0.9.0.1/bin/kafka-server-start.sh -daemon /usr/local/kafka_2.11-0.9.0.1/config/server.properties

 

四,创建topic

 

输入命令创建一个叫test的topic:bin/kafka-console-producer.sh --broker-list 192.168.50.42:9092 --topic test

消费topic的命令:bin/kafka-console-consumer.sh --zookeeper 192.168.50.42:2181 --topic test --from-beginning

 


 
 

五,扫描Nginx日志发送到kafka

 

tail -n 0 -f  /htlog/ht-video.log | /usr/local/kafka_2.10-0.9.0.1/bin/kafka-console-producer.sh --broker-list 192.168.50.42:9092 --topic test

 

六,java客户端消费日志

 

public static List<String> getKafkaData(){
    	List<String> list=new ArrayList<String>();
    	Properties props = new Properties();
    	props.put("zookeeper.connect", "192.168.50.42:2181");
    	props.put("group.id", "group");
    	props.put("zookeeper.session.timeout.ms", "40000");
    	props.put("zookeeper.sync.time.ms", "200");
    	props.put("auto.commit.interval.ms", "1000");
    	ConsumerConnector consumer = kafka.consumer.Consumer.createJavaConsumerConnector(new ConsumerConfig(props));
        Map<String, Integer> topicCountMap = new HashMap<String, Integer>();
        topicCountMap.put("test", new Integer(1));
        Map<String, List<KafkaStream<byte[], byte[]>>> consumerMap = consumer.createMessageStreams(topicCountMap);
        KafkaStream<byte[], byte[]> stream = consumerMap.get(Kafkaproperties.topic).get(0);
        ConsumerIterator<byte[], byte[]> it = stream.iterator();
        String message="GGGG";
        while (it.hasNext()) {
        	message=new String(it.next().message());
            System.out.println("receive:" + message);
            list.add(message);
        }
    	return list;
    }

 

 

  • 大小: 7.1 KB
  • 大小: 31.4 KB
分享到:
评论

相关推荐

    微信小程序云商城php后端

    例如,通过GET请求获取商品列表,通过POST请求提交用户订单,通过PUT或PATCH更新订单状态等。这些接口通常采用RESTful设计原则,遵循一定的HTTP方法和状态码规范。 数据库设计是云商城的重要组成部分。通常会包含...

    留言程序2

    这些接口规定了请求方法(GET、POST、PUT、DELETE等)、URL路径、请求参数及返回格式,使得前后端可以解耦合。 5. **用户认证与授权**:确保用户安全登录和操作,通常需要实现用户注册、登录功能,涉及到密码加密、...

    商城小程序JAVA后台

    3. **RESTful API设计**:为了与前端小程序通信,后台通常会提供RESTful风格的API接口,遵循HTTP协议,通过GET、POST、PUT、DELETE等方法操作资源,实现前后端分离。 4. **数据库设计**:数据库是存储商品信息、...

    基于SpringBoot的秒杀系统.zip

    用户发起秒杀请求后,系统只记录请求,不立即执行扣减库存,而是将请求放入消息队列,后台服务再消费这些请求,实现解耦和削峰填谷。 8. **幂等性设计**:考虑到网络重试等因素,秒杀请求必须是幂等的,即相同的...

    java软件工程师面试基本题.docx

    13. **Ajax的POST和GET**:POST用于发送大量数据或修改数据,GET用于获取数据,数据显示在URL中。 14. **Nginx反向代理**:Nginx可作为反向代理服务器,用于转发请求到后端服务器。 15. **项目职责**:面试者需要...

    【头条项目】后台初始代码.zip

    7. **负载均衡与集群**:为了应对高并发访问,需要设置负载均衡器,如Nginx,将请求分发到多个服务器,同时考虑数据库读写分离和服务器集群。 8. **日志与监控**:利用Logstash、Elasticsearch、Kibana(ELK栈)...

    app后台服务器java

    在构建一个app后台服务器的过程中,Java作为一门强大且广泛应用的编程语言,经常被用来开发服务端程序。这里我们将深入探讨如何使用Java来构建一个高效、可靠的app后台服务器。 首先,理解"服务器Java"这个标签,它...

    zmyy-seckill-master.zip(知苗易约抢购程序)

    这涉及状态码、资源表示和HTTP动词的合理使用,如GET、POST、PUT和DELETE。 5. **分布式系统**:在高并发环境下,单机可能无法承载所有请求,因此可能采用了负载均衡和分布式服务技术,如Nginx、Apache HTTP Server...

    仿微信安卓聊天软件 服务端 backend

    理解HTTP方法(GET、POST、PUT、DELETE)和状态码对于构建API至关重要。 3. **WebSocket协议**:即时通讯应用需要实时的数据交换,WebSocket提供了全双工、低延迟的通信方式。在Java后端,我们可能使用Jetty或...

    服务间通讯带源码

    8. **监控和日志**:对于生产环境,服务间的通信需要被监控和记录,以便于故障排查和性能优化。Prometheus、Grafana、ELK Stack(Elasticsearch、Logstash、Kibana)等工具可以辅助这一过程。 在这个压缩包中,...

    大规模Web服务开发技术

    2. RESTful API设计:REST(Representational State Transfer)是一种网络应用程序的设计风格和开发方式,基于HTTP协议,通过URI(Uniform Resource Identifier)来定位资源,使用HTTP动词(GET、POST、PUT、DELETE...

    西安电子科技大学B测雾霾探测系统后端.zip

    8. **监控与日志**:为了确保系统的稳定运行,需要实施日志记录和系统监控,如使用ELK(Elasticsearch、Logstash、Kibana)堆栈收集和分析日志,通过Prometheus或Grafana监控系统性能指标。 9. **测试与部署**:...

    SpringBoot实现Java高并发秒杀系统.zip

    11. **负载均衡**:使用Nginx或Spring Cloud Gateway作为反向代理和负载均衡器,分散前端请求到多个后端实例,提高系统可用性。 12. **单元测试与集成测试**:编写详尽的单元测试和集成测试,确保每个模块和接口在...

    java电商后台.zip

    12. **日志和监控**:日志系统如Log4j和ELK栈(Elasticsearch、Logstash、Kibana)用于记录和分析系统运行情况,Prometheus和Grafana则用于系统监控和性能指标展示。 13. **单元测试和集成测试**:使用JUnit、...

    跨域上传文件,多服务器相互调用

    2. JSONP(JSON with Padding):这是一种早期解决跨域问题的方法,适用于只支持GET请求的旧版浏览器。它通过动态插入`&lt;script&gt;`标签来实现跨域通信,但不支持POST请求和文件上传。 3. formData与XMLHttpRequest:...

    电子商务开发源码服务端

    这些接口遵循HTTP协议,通过GET、POST、PUT、DELETE等方法处理客户端的请求。 4. **数据库管理**:服务端需要处理大量的数据,因此数据库管理是核心任务。常见的关系型数据库有MySQL、PostgreSQL,非关系型数据库有...

    基于SpringBoot的高并发商品限时秒杀系统.zip

    遵循REST原则,我们可以设计清晰、无状态的API,例如GET用于获取商品信息,POST用于发起秒杀请求。 3. **数据持久层**:SpringBoot与JPA(Java Persistence API)或MyBatis结合,用于数据库操作。在秒杀场景中,...

    综合code

    3. **API设计**:RESTful API设计原则,定义HTTP动词(GET, POST, PUT, DELETE)和资源路径。 4. **安全实践**:密码哈希与加盐,防止SQL注入和XSS攻击的安全措施。 5. **错误处理**:优雅的错误处理机制,提供详细...

    web 后台管理框架

    Web后台管理框架是用于构建高效、可扩展且易于维护的Web应用程序的重要工具。它整合了多种技术,如前端模板引擎、后端路由、数据库交互、权限控制等,为开发者提供了一套完整的解决方案,大大简化了开发流程。下面将...

Global site tag (gtag.js) - Google Analytics