多进程用户并发处理Demo(C#版)
这个示例主要演示的是在多进程操作数据库时,如何避免并发重复数据入库的例子。
过多的线程理论不再阐述,网上、书上皆有。
项目采用 Asp.Net Framework 4.5 / Mysql 5.4 数据库。
首先创建一个 LockInsertDB.cs 文件,这个文件用来实现数据库添加;
1 using System;
2 using MySql;
3 using MySql.Data.MySqlClient;
4 using System.Collections.Generic;
5 using System.Linq;
6 using System.Text;
7 using System.Threading.Tasks;
8
9 namespace DBImportTool
{
public class LockInsertDB : Common
{
private object obj = new object();
/// <summary>
/// 添加测试数据
/// </summary>
/// <param name="path">字段内容</param>
/// <param name="tname">线程名称</param>
public void InsertTestDB(string path, object tname)
{
MySql.Data.MySqlClient.MySqlConnection conn = new MySql.Data.MySqlClient.MySqlConnection("Server=10.17.1.57; Database=videodb; Uid=root; Pwd=xingzhi");
try
{
conn.Open();//打开连接
MySql.Data.MySqlClient.MySqlCommand cmd = new MySql.Data.MySqlClient.MySqlCommand();
cmd.Connection = conn;
//加入多线程,排它锁机制.
lock (obj)
{
string select = "SELECT * FROM `tbl_test` WHERE `filepath` = '" + path + "'";
cmd.CommandText = select;
object val = cmd.ExecuteScalar();
if (val == null)
{
string sql = "INSERT INTO `tbl_test` (`filepath`, `addtime`) VALUES ('" + path + "', NOW());";
cmd.CommandText = sql;
cmd.ExecuteNonQuery();
P(DateTime.Now.ToString() + "\t" + tname + "\tOK\t" + path + "\n");
}
else
{
P(DateTime.Now.ToString() + "\t" + tname + "\t已存在\t" + path + "\n");
}
}
}
catch
{
}
finally
{
//关闭连接
conn.Close();
}
}
/// <summary>
/// 测试输出
/// </summary>
/// <param name="str">输出内容字符串</param>
public void P(string str)
{
Console.Write(str);
}
}
65 }
再创建一个控制台工程,Main方法代码如下:
1 using System;
2 using System.Threading;
3 using System.IO;
4 using System.Collections.Generic;
5 using System.Linq;
6 using System.Text;
7 using System.Threading.Tasks;
8 namespace DBImportTool
9 {
public class Mcqueen
{
static void Main(string[] args)
{
Run();
Console.ReadLine();
}
/// <summary>
/// 进程数量.
/// </summary>
static int tnum = ;
/// <summary>
/// 所对象
/// </summary>
static object obj = new object();
/// <summary>
/// 线程数组.
/// </summary>
static Thread[] threadarr = new Thread[tnum];
/// <summary>
/// 数据库插入对象.
/// </summary>
static LockInsertDB mdb = new LockInsertDB();
/// <summary>
/// 运行函数
/// </summary>
public static void Run()
{
for (int i = ; i < tnum; i++)
{
Thread t = new Thread(T1);
threadarr[i] = t;
threadarr[i].Name = "Thread " + i.ToString() + " :";
}
int y = ;
while (y < tnum)
{
threadarr[y].Start(threadarr[y].Name);
y++;
}
}
/// <summary>
/// 读取磁盘文件路径.
/// </summary>
/// <param name="tname">线程名称</param>
public static void T1(object tname)
{
DirectoryInfo di = Directory.CreateDirectory(@"F:\邢智的文件\");
GetFiles(di, tname);
}
/// <summary>
/// 采用对列入栈模式对列遍历文件夹结构.
/// </summary>
/// <param name="di">目录对象</param>
/// <param name="tobj">线程名称</param>
private static void GetFiles(DirectoryInfo di,object tobj)
{
int sgin = ;
Stack<DirectoryInfo> stack_dir = new Stack<DirectoryInfo>();
DirectoryInfo dir = di;
stack_dir.Push(di);
while (stack_dir.Count != )
{
dir = stack_dir.Pop();
DirectoryInfo[] diarr = dir.GetDirectories();
foreach (DirectoryInfo d in diarr)
stack_dir.Push(d);
FileInfo[] files = dir.GetFiles();
foreach (FileInfo f in files)
{
mdb.InsertTestDB(f.FullName.Replace("\\", "\\\\"), tobj);
Thread.Sleep();
sgin++;
}
}
}
public static void P(string str)
{
Console.Write(str);
}
}
91 }
static LockInsertDB mdb = new LockInsertDB();
一开始把这句初始化对象放到了private static void GetFiles(DirectoryInfo di,object tobj) 函数里面,虽然在后续的执行过程中没有任何问题,
但是初始化运行线程时导致了进程并发进入lock锁中,后来研究一下原因,是因为每个进程都在实例化化它的时候都会在lock中分配一个标识符,
这样一来,假如A进程内实例化了A1,那么当B进程进来之后,B却不认识A线程内的A1,因此lock也就对A1不起作用了。
因此把这个类跳出线程而放到一个全局中去实例化,也就不存在这个lock失效的问题了。
运行结果如下:

如果需要模拟更多的进程用户,只需要把 tnum = 2 的数值改一下即可。
多进程用户并发处理Demo(C#版)的更多相关文章
- EasyUI+MVC+EF简单用户管理Demo(问题及解决)
写在前面 iframe-src EntityFramework版本 connectionStrings View.Action.页面跳转 EasyUI中DataGrid绑定 新增.修改和删除数据 效果 ...
- vue入门:用户管理demo
该demo纯前端实现 使用到vue技术点: 1.在该demo中使用到的vue指令:{{}}. v-if. v-model. @click v-for 2.在该demo中使用到的事件修饰符: .prev ...
- Win7隐藏登录界面中的用户(不建议HOME版使用)
一天一點 能登多高,靠的不是双脚!能看多远,靠的不是双眼!人生路,贵在坚持! Win7隐藏登录界面中的用户(不建议HOME版使用) Win7中如何隐藏不想出现在登录界面中的用户 在Windows系统管 ...
- PHP多进程学习(一)__来初步了解一下PHP多进程及简单demo
php是一门单进程弱类型的语言,PHP处理多并发主要是依赖服务器或PHP-FPM的多进程及它们进程的复用,多进程的作用优点大家可以去网上了解,PHP实现多进程在实际项目中意义也是不容小觑的.比如:日常 ...
- WordPress 前端投稿/编辑发表文章插件 DJD Site Post(支持游客和已注册用户)汉化版 免费下载
插件简介 前面逍遥乐给大家推荐了 WordPress用户前端化专业版WP User Frontend Pro WordPress中文汉化插件v2.1.9 今天逍遥乐给大家带来的wordpress插件是 ...
- apache通过.htaccess(rewrite)判断手机电脑跳转-手机用户重定向到手机版
自动判断.重定向的办法也有几种: 使用网站构建的程序(例如PHP)来判断.重定向:使用服务器上的Web服务(例如Apache)来判断.重定向. 在Apache中设置重定向有两个办法: 在网站的http ...
- JavaCPP快速入门(官方demo增强版)
欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...
- hadoop streaming编程小demo(python版)
大数据团队搞数据质量评测.自动化质检和监控平台是用django,MR也是通过python实现的.(后来发现有orc压缩问题,python不知道怎么解决,正在改成java版本) 这里展示一个python ...
- spring boot一个简单用户管理DEMO
概述 该Demo旨在部署一个简单spring boot工程,包含数据编辑和查看功能 POM配置 <?xml version="1.0" encoding="UTF- ...
随机推荐
- ESCAPE用法
ESCAPE用法1.使用 ESCAPE 关键字定义转义符: 在模式中,当转义符置于通配符之前时,该通配符就解释为普通字符. 2.ESCAPE 'escape_character' 允许在字符串中搜索通 ...
- Android应用程序组件Content Provider应用实例
文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6950440 文简要介绍了Android应用程序 ...
- 【贪心+中位数】【UVa 11300】 分金币
(解方程建模+中位数求最短累积位移) 分金币(Spreading the Wealth, UVa 11300) 圆桌旁坐着n个人,每人有一定数量的金币,金币总数能被n整除.每个人可以给他左右相邻的人一 ...
- WPS页面设置
以前使用WPS的时候遇到一些问题: 比如我输入一个英文的时候它总是自动的给我首字母大写,但是某些情况下我不想这样: 从VS中复制代码的时候不希望他吧那些颜色复制下来: 还有我输入1回车后它自动给我输入 ...
- Jquery 工具类函数
1.$.browser 获取当前浏览器的名称和版本信息 $.browser.chrome 获取chrome浏览器 $.browser.mozilla 获取火狐浏览器 $.browser.msie ...
- stl的集合set——安迪的第一个字典(摘)
set就是数学上的集合——每个元素最多只出现一次,和sort一样,自定义类型也可以构造set,但同样必须定义“小于”运算符 以下代码测试set中无重复元素 #include<iostream&g ...
- optimize table 表优化问题
语法: optimize table '表名' 一,原始数据 1,数据量 2,存放在硬盘中的表文件大小 3,查看一下索引信息 索引信息中的列的信息说明. Table :表的名称.Non_unique: ...
- 记微信开发(有道翻译api)
记微信开发(有道翻译api) 记微信开发(有道翻译api) 效果: 有道翻译api申请: 地址:http://fanyi.youdao.com/openapi code: <?php/** * ...
- strace排除Linux服务器故障
strace是一个有用的小工具 – 大多数Linux系统默认已经安装 – 可以通过跟踪系统调用来让你知道一个程序在后台所做的事情.Strace是一个基础的调试工具;但是即便你不是在跟踪一个问题的时候它 ...
- Ubuntu系统下创建python数据挖掘虚拟环境
虚拟环境: 虚拟环境是用于创建独立的python环境,允许我们使用不同的python模块和版本,而不混淆. 让我们了解一下产品研发过程中虚拟环境的必要性,在python项目中,显然经常要使用不 ...