0
我正在使用OpcNetApi与kepware进行通信。我尝试从kepware中读取一些值(超过40个值)然而,当我的程序执行opc服务器的读取方法时,它会等待大约10秒钟来读取我想要的值。这太多了。我不希望它等那么多。我希望它执行读取方法最多1秒,我不知道是什么问题。为什么opc读取值非常慢?有什么办法可以让它更快。OpcNetApi从kepware缓慢读取
这里是我的OPC类
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows.Forms;
namespace VestelTest
{
class clsOPC
{
private static Opc.Da.Server server = null;
private static Opc.Da.SubscriptionState groupState;
private static Opc.Da.Subscription group;
public clsOPC()
{
}
public static void Connect()
{
//OpcCom.ServerEnumerator se = new OpcCom.ServerEnumerator();
//Opc.Server[] servers = se.GetAvailableServers(Opc.Specification.COM_DA_20);
//Opc.Da.Server server = null;
Opc.URL url = new Opc.URL("opcda://localhost/KEPware.KEPServerEX.V4");
OpcCom.Factory fact = new OpcCom.Factory();
server = new Opc.Da.Server(fact, url);
server.Connect();
groupState = new Opc.Da.SubscriptionState();
groupState.Name = "Salla";
groupState.Active = false;
group = (Opc.Da.Subscription)server.CreateSubscription(groupState);
}
public static void Read(Opc.Da.Item[] items, Opc.Da.ReadCompleteEventHandler method)
{
//Opc.Da.ItemValueResult[] sonuclar = group.Read(group.Items);
if (group != null)
{
//server.Subscriptions.Clear();
groupState = new Opc.Da.SubscriptionState();
groupState.Name = "Salla";
groupState.Active = false;
server.CancelSubscription(group);
group = null;
group = (Opc.Da.Subscription)server.CreateSubscription(groupState);
items = group.AddItems(items);
Opc.IRequest req;
group.Read(group.Items, 123, method, out req);
}
//return sonuclar;
}
public static Opc.Da.ItemValueResult[] Read(Opc.Da.Item[] items)
{
Opc.Da.ItemValueResult[] sonuclar = new Opc.Da.ItemValueResult[items.Length];
if (group != null)
{
//server.Subscriptions.Clear();
groupState = new Opc.Da.SubscriptionState();
groupState.Name = "Salla";
groupState.Active = false;
server.CancelSubscription(group);
group = null;
group = (Opc.Da.Subscription)server.CreateSubscription(groupState);
items = group.AddItems(items);
//sonuclar = group.Read(group.Items);
sonuclar = server.Read(items);
}
return sonuclar;
}
public static void Write(Opc.Da.Item[] writeItems, Opc.Da.ItemValue[] writeValues, Opc.Da.WriteCompleteEventHandler method, Opc.Da.ReadCompleteEventHandler methodRead)
{
if (group != null)
{
//server.Subscriptions.Clear();
groupState = new Opc.Da.SubscriptionState();
groupState.Name = "Salla";
groupState.Active = false;
server.CancelSubscription(group);
group = null;
group = (Opc.Da.Subscription)server.CreateSubscription(groupState);
writeItems = group.AddItems(writeItems);
for (int i = 0; i < writeItems.Length; i++)
{
if (writeValues[i] != null)
writeValues[i].ServerHandle = group.Items[i].ServerHandle;
}
Opc.IRequest req;
group.Write(writeValues, 321, method, out req);
System.Threading.Thread.Sleep(1000);
group.Read(group.Items, 123, methodRead, out req);
}
}
public static void Write(Opc.Da.Item[] writeItems, Opc.Da.ItemValue[] writeValues)
{
if (group != null)
{
//server.Subscriptions.Clear();
groupState = new Opc.Da.SubscriptionState();
groupState.Name = "Salla";
groupState.Active = false;
server.CancelSubscription(group);
group = null;
group = (Opc.Da.Subscription)server.CreateSubscription(groupState);
writeItems = group.AddItems(writeItems);
for (int i = 0; i < writeItems.Length; i++)
{
if (writeValues[i] != null)
writeValues[i].ServerHandle = group.Items[i].ServerHandle;
}
Opc.IRequest req;
group.Write(writeValues);
}
}
public static void Disconnect()
{
server.Disconnect();
}
static void ReadCompleteCallback(object clientHandle, Opc.Da.ItemValueResult[] results)
{
Console.WriteLine("Read completed");
foreach (Opc.Da.ItemValueResult readResult in results)
{
Console.WriteLine("\t{0}\tval:{1}", readResult.ItemName, readResult.Value);
}
Console.WriteLine();
}
static void WriteCompleteCallback(object clientHandle, Opc.IdentifiedResult[] results)
{
Console.WriteLine("Write completed");
foreach (Opc.IdentifiedResult writeResult in results)
{
Console.WriteLine("\t{0} write result: {1}", writeResult.ItemName, writeResult.ResultID);
}
Console.WriteLine();
}
}
}
我这样使用它;
int deviceID = vChannelDevice[i].device.ID;
var vAdres = (from adres in d.tblAddress join groupp in d.tblGroup on adres.GroupID equals groupp.ID join device in d.tblDevice on groupp.DeviceID equals device.ID where device.ID == deviceID select new { adres, groupp, device }).ToList();
if (vAdres.Count > 0)
{
Opc.Da.Item[] valueItems = new Opc.Da.Item[vAdres.Count];
for (int j = 0; j < vAdres.Count; j++)
{
valueItems[j] = new Opc.Da.Item();
valueItems[j].ItemName = vChannelDevice[i].channel.Ad + "." + vChannelDevice[i].device.Ad + "." + vAdres[j].groupp.Ad + "." + vAdres[j].adres.Ad;
}
Opc.Da.ItemValueResult[] valueResults = new Opc.Da.ItemValueResult[vAdres.Count];
if (backgroundWorker1.CancellationPending)
{
e.Cancel = true;
return;
}
valueResults = clsOPC.Read(valueItems);
for (int j = 0; j < vAdres.Count; j++)
{
if (valueResults[j] != null)
{
if (valueResults[j].Value != null)
{
Kaydet(vAdres[j].adres.ID, Convert.ToDouble(valueResults[j].Value), donguTarih);
}
}
}
}
valueResults = clsOPC.Read(valueItems);
等待太行
凡在'阅读()'不会暂停发生的方法?是否在'sonuclar = server.Read(items);'行上? – DonBoitnott 2014-10-09 11:39:44
是的,这是正确的。 – MOD 2014-10-09 11:45:59
然后似乎很清楚,它是服务器的响应滞后,而不是您对值的请求。 – DonBoitnott 2014-10-09 11:47:20