Java的多线程+Socket 后台 Ver 2.0
package com.wulala;
import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
public class JavaThreadCreationAndRun {
public static void main(String[] args) {
JavaThreadCreationAndRun jtca = new JavaThreadCreationAndRun();
jtca.startServer();
}
public void startServer() {
ServerSocket ss = null;
try {
ss = new ServerSocket(9999);
} catch (IOException e) {
e.printStackTrace();
}
UpdateMySQL updateMySQL;
while (true) {
Socket socket = null;
try {
socket = ss.accept();
updateMySQL = new UpdateMySQL(socket);
Thread thread = new Thread(updateMySQL);
thread.start();
} catch (IOException e1) {
System.out.println("client disconnected");
try {
socket.close();
} catch (IOException e) {
System.out.println("close socket false: " + e.getMessage());
}
}
}
}
//请无视下面这个内部类.
static class Helper implements Runnable {
private final String message;
public Helper(String _message) {
this.message = _message;
}
private void doSomething(String meesage) {
System.out.println("The doSomethig method was executed by thread:" + Thread.currentThread().getName());
System.out.println("Do something with " + message);
}
@Override
public void run() {
for (int i = 0; i < 2; i++) {
doSomething(message);
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
}
把进程的继承类独立出来了:
package com.wulala;
import java.io.IOException;
import java.io.InputStream;
import java.net.Socket;
public class UpdateMySQL extends Thread {
private InputStream is = null;
byte b[] = new byte[1024];
int readCount = 0;
ExecuteDML edml;
public UpdateMySQL(Socket socket) {
edml = new ExecuteDML();
try {
edml.initParam("dbconfig.properties");
} catch (Exception e2) {
System.out.println("init deml fail: " + e2.getMessage());
}
try {
is = socket.getInputStream();
} catch (IOException e1) {
System.out.println("getInputStream exception: " + e1.getMessage());
}
try {
readCount = is.read(b);
System.out.println("readCount is " + readCount);
} catch (IOException e1) {
System.out.println("readCounter fail: " + e1.getMessage());
} catch (Exception e) {
try {
is.close();
} catch (IOException e1) {
System.out.println("is close exeption: " + e1.getMessage());
}
// pw.close();
try {
socket.close();
} catch (IOException e1) {
System.out.println("socket close exeption: " + e1.getMessage());
}
System.out.println("socket exeption: " + e.getMessage());
}
}
@Override
public void run() {
String str;
str = new String(b);
str = str.trim();
System.out.println("Client Socket Message:" + str);
String deviceID = "";
int activate = 0;
if (str.length() > 8 && (str.length() < 15)) {
int insertResult = 0;
// ExecuteDML edml = new ExecuteDML();
deviceID = str.substring(0, 8);
activate = Integer.valueOf(str.substring(8));
try {
insertResult = edml.insertWXData(deviceID, activate);
} catch (Exception e) {
System.out.println("insert problem" + e.getMessage());
}
// System.out.println("deviceID: " + deviceID + " activate: " +
// activate);
}
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
System.out.println("sleep problem..");
}
}
}
重新把多线程看了一下, 现在基本知道怎么监控线程的情况了, 可惜还是没有在Cent OS上面安装Java SDK(公司网速慢成狗), 所以没法在生产用服务器上用jstack监控, 回头想办法把jdk的rpm倒腾到生产服务器上去, 试试监控.
现在主要是用netstat跟ps看状态了, ps看到的总是没问题的, 进程还在, netstat -an|grep 9999看到的如果是一堆的WAIT_TO_CLOSE什么的, 就嗝了.
继续观察吧.
Java的多线程+Socket 后台 Ver 2.0的更多相关文章
- Java的多线程+Socket 后台
打包好可执行的jar文件之后, 用ftp上传到服务器, 用nohup命令, 让这个服务器在后台运行, 并将输出重定向到log文件中, 命令是: #nohup java -jar MTSServer.j ...
- Java的多线程+Socket
客户端: package com.wulala; import java.io.FileOutputStream;import java.io.IOException;import java.io.I ...
- Java多线程 Socket使用
点我跳过黑哥的卑鄙广告行为,进入正文. Java多线程系列更新中~ 正式篇: Java多线程(一) 什么是线程 Java多线程(二)关于多线程的CPU密集型和IO密集型这件事 Java多线程(三)如何 ...
- Java 多线程 socket 取款例子 runnable callable
socket部分参考 http://blog.csdn.net/kongxx/article/details/7259465 取款部分参考 http://blog.csdn.net/dayday198 ...
- Unable to open debugger port (127.0.0.1:51554): java.net.SocketException "socket closed"
刚开始使用IDEA 总是有各种各样奇葩的问题 启动报错: Unable to open debugger port (127.0.0.1:51554): java.net.SocketExceptio ...
- IDEA项目启动报Unable to open debugger port (127.0.0.1:51554): java.net.SocketException "socket closed"
启动报错: Unable to open debugger port (127.0.0.1:51554): java.net.SocketException "socket closed&q ...
- IntelliJ IDEA 启动tomcat 报错: idea Unable to open debugger port (127.0.0.1:58233): java.net.SocketException "socket closed"
debug启动项目弹出提示 Error running omp: Unable to open debugger port (127.0.0.1:50812): java.net.SocketExce ...
- Unable to open debugger port (127.0.0.1:63959): java.net.SocketException "socket closed",编译过来就是无法打开调试器端口,套接字已关闭
最开始的预测: 这台笔记本操作系统是win10专业工作站版,debug启动项目,provide项目完美启动成功,然后consumer项目报错:Unable to open debugger port ...
- java程序报错:Unable to open debugger port (127.0.0.1:63959): java.net.SocketException "socket closed",编译过来就是无法打开调试器端口,套接字已关闭
报错:Unable to open debugger port (127.0.0.1:63959): java.net.SocketException "socket closed" ...
随机推荐
- linux 进入mysql
mysql -u root -ppassword show databases; \h 帮助 \q 退出
- C# Albert工程阅读关键字解析
// 摘要: // 为强类型集合提供 abstract 基类. [Serializable] [ComVisible(true)] public abstract class CollectionBa ...
- django 用户登陆注册
注册登陆 views.py #!/usr/bin/env python # -*- coding:utf- -*- from django.shortcuts import render,render ...
- nginx地址重写
1. 域名重定向 server_name wx.he.com weixin.ha.com; if ($http_host !~* "wx\.he\.com"){ rewrite ^ ...
- openssl HeartBlood
受影响[编辑] OpenSSL 1.0.2-beta OpenSSL 1.0.1 - OpenSSL 1.0.1f 除非针对CVE-2014-0160的操作系统补丁已经安装,而没有更改库版本,如Deb ...
- Real-Time SQL Monitoring
Real-Time SQL Monitoring可以在sql运行的时候监控其性能. 缺省情况下,单个sql执行花费的CPU或I/O时间超过5秒或sql并行执行的时候,Real-Time SQL Mon ...
- [转]EntityFramework走马观花之CRUD(下)
学习Entity Framework技术期间查阅的优秀文章,出于以后方便查阅的缘故,转载至Blog,可查阅原文:http://blog.csdn.net/bitfan/article/details/ ...
- centos Flash Player插件的安装
关于Flash Player插件的安装,其实Fedora官方Wiki文档已经给出了详细的说明,我这里再把重点提取一下: 1. 首先到Adobe Flash Plugin官方下载页面选择YUM for ...
- PostgreSQL单机、同步复制、异步复制性能测试对比
测试环境: •测试机:PC •内存:8GB •CPU:Intel(R) Core(TM) i5-3450 3.10GHz •硬盘:HDD •数据量:20GB •测试工具:pgbench •Postgr ...
- eclipse JAVA 类元素 快速添加set和get方法
鼠标在代码窗口,鼠标右键 然后选择如下图 然后在下面图中,选择需要个类的元素添加的set和get 选择好了点击OK,这样eclipse就自动生成get和set方法