Microsoft MVP성태의 닷넷 이야기
C# Lock 관련해서 질문드립니다. [링크 복사], [링크+제목 복사],
조회: 18465
글쓴 사람
힘찬도약 (kssjjw71 at hanmail.net)
홈페이지
첨부 파일
 

안녕하세요.

C# Multi threads, lock, queue관련해서 질문드립니다.
아래와 같은 코드에서 lstServers 객체를 30개 정도 만든다고 가정할때
각 객체들이 Network에서 async하게 받은 데이터를 동시에 하나의 queue에 넣을 때
lock이 걸려서 queue가 깨지는 일은 없지만, load때문에 간혹 쓰지 못하는 경우가 발생합니다.
이럴 경우 어떻게 해결할 수 있을지 잘 모르겠습니다.

public class MainClient : Form
{
    public static Queue Q = new Queue<byte[]>();
    InitializeComponent();

     private void btnConnect_Click(object sender, EventArgs e)
     {
        lstServers = new List<SocketNetworks>();
        lstServers.Add(new SocketNetworks("127.0.0.1", 1111));
        lstServers.Add(new SocketNetworks("127.0.0.1", 2222));

        for (int i = 0; i < lstServers.Count; i++)
        {
            lstServers[i].Server_Connect();
        }
     }

     public static void DataInsertQueue(byte[] buff)
     {
        lock (Q)
        {
           Q.Add(buff);
        }
     }
}


public class SocketNetworks : MainClient
{
  public SocketNetworks(string serverIP, int serverPort)
  {
     this.serverIP = serverIP;
     this.serverPort = serverPort;
  }
  
   public void Server_Connect()
   {
       //... Socket networks..
   }
   // ....
   private void ReceiveCallBack(IAsyncResult ar)
   {
       byte[] Ibuff = (byte[])ar.AsyncState;
       int recv = ClientSocket.EndReceive(ar);
       
       // 다수의 작업.. parsing packets and control servers등 후

       MainClient.DataInsertQueue(Ibuff); <<<<<<<<<<<<<
   }
   ...
}








[최초 등록일: ]
[최종 수정일: 10/27/2015]


비밀번호

댓글 작성자
 



2015-10-27 02시08분
Q에서 받는 코드부분에서 lock을 어떻게 처리하셨나요? 그 부분에서 긴 시간이 소요되면 병목이 걸릴 수 있습니다.
정성태
2015-10-27 11시07분
[ryujh] 안녕하세요.
List<SocketNetworks> 가 30개 정도 만들고 호출 결과를 byte[] 로 받아서 Queue 에 추가한다면

List<SocketNetworks> 에 index를(순번을) 가지고 호출 결과에 new object[] { index, byte[] } 로 받아서
Queue 대신에 byte[30][] (byte[] 가 30개 배열) 에 index 직접 지정해서 할당하는 것은 어떨지 알려드립니다.

public static byte[][] Q2 = new byte[30][];

...

object[] Ibuffobj = (object[])ar.AsyncState;
int index = (int)Ibuffobj[0];
byte[] Ibuff = (byte[])Ibuffobj[1];
Q2[index] = Ibuff;

참고하십시오.
[guest]
2015-10-28 01시46분
[힘찬도약] Q에서 dequeue하는 것은 1000개정도 queue를 잡아놓고 예) 짧은 주기에 한번씩 10개이상씩 dequeue하고 Q.Count를 찍어보면 많았다가 0으로 금방 수렴하는 것이 확인됩니다. ryujh님께서 알려주신 방법을 적용해보면 많은 도움이 될것 같습니다.
정말 정말 감사합니다. ^^
[guest]
2015-10-28 03시43분
[힘찬도약] 하나의 Q에서 DB에 Write해야 하는 구조여서, 최대한 packet을 안 잃어버리는 방법이...?
ryujh님께서 말씀하신 버퍼에 일단 저장해놓고 threads를 만들어야 기다리면서 써야 하는지? 이게 말이 되는 것인지요?

[guest]
2015-10-28 07시47분
[ryujh] 스레드별 소켓(30개 각각) -> 결과를 Q에 저장 -> 어쨌든 Q가 DB에 기록

이렇다면 제가 아까 알려드렸던 방법은 30개 호출하고 Q에 1회 저장하면 그걸로 끝으로 가정한 것입니다.
만약 DB에 기록하고 다시 소켓 -> Q에 저장 이렇게 간다면

public static object[] Qobj = new object[30*소켓결과보존개수];
또는 구조체나 클래스로 타입을 만든다음 그 타입의 배열을 할당하는 것.

타입은
시각(DateTime), 소켓의 인덱스(int), 소켓의 결과(byte[]), 상태값(int, bool), 그 외 등을 묶는 것입니다.

순환하면서 Q -> DB 에 기록하려면 필요한 것이 별도 스레드 둬서 순환하면서 DB에 기록해야 할 것 같습니다.
소켓개수와 상관없이 Q -> DB에 기록하는 업무단위 스레드입니다.

참고하십시오.



[guest]
2015-10-28 09시11분
[힘찬도약] 참으로 감사합니다. 말씀해주신 조언을 참조해서 잘 적용하겠습니다. 도움주셔서 감사합니다. 감사합니다.
[guest]

... 91  92  [93]  94  95  96  97 
NoWriterDateCnt.TitleFile(s)
137정성태4/7/200510136            답변글 [답변]: [답변]: [답변]: c# .Net 에 대한 문의좀 ^^ [WinForm 에서 UserControl로 작성된 폼을 호출하려는데....]
138김용국4/7/20059075                답변글 [답변]: [답변]: [답변]: [답변]: c# .Net 에 대한 문의좀 ^^ [WinForm 에서 UserControl로 작성된 폼을 호출하려는데....]
139김용국4/11/20059602                    답변글 잘 해결 되었습니다... 감사합니다 [한줄답변]
129김용국3/31/200510541SmartClient 배포와 관련해서 무엇이 빠졌는지 좀 알려주시면 감사하겠습니다....!파일 다운로드2
130정성태3/31/20059708    답변글 [답변]: SmartClient 배포와 관련해서 무엇이 빠졌는지 좀 알려주시면 감사하겠습니다....!
131김용국4/1/20059177        답변글 [답변]: [답변]: SmartClient 배포와 관련해서 무엇이 빠졌는지 좀 알려주시면 감사하겠습니다....!
132정성태4/1/20059345            답변글 [답변]: [답변]: [답변]: SmartClient 배포와 관련해서 무엇이 빠졌는지 좀 알려주시면 감사하겠습니다....!
133김용국4/1/20059473                답변글 [답변]: [답변]: [답변]: [답변]: SmartClient 배포와 관련해서 무엇이 빠졌는지 좀 알려주시면 감사하겠습니다....!
126구정모3/31/200510783이홈의 효과는 어떻게???
128정성태3/31/20059889    답변글 [답변]: 이홈의 효과는 어떻게???
124배재현3/30/20059879Smart Client 문제로 이렇게 질문을 하나 올리게 됐습니다.^^;;
125정성태3/30/20059343    답변글 [답변]: Smart Client 문제로 이렇게 질문을 하나 올리게 됐습니다.^^;;
121안연준3/23/20059264이벤트 관련 문제
122정성태3/23/20059145    답변글 [답변]: 이벤트 관련 문제
120안연준3/23/20059006정성태님.... 오프라인 문제 질문 입니다. [1]
123정성태3/23/20059231    답변글 [답변]: 정성태님.... 오프라인 문제 질문 입니다. [1]
117정준명3/21/200510142COM+ 메소드 작성시...
118정성태3/29/20059720    답변글 [답변]: COM+ 메소드 작성시... [1]
109김용국3/18/200510675IE에 Docking된 WinFormControl내의 특정 메소드에 값을 보내기 .. 잘 되기는 하는데 한가지 문제가 ...
112정성태3/19/20059837    답변글 [답변]: IE에 Docking된 WinFormControl내의 특정 메소드에 값을 보내기 .. 잘 되기는 하는데 한가지 문제가 ...
113김용국3/19/20059803        답변글 [답변]: [답변]: IE에 Docking된 WinFormControl내의 특정 메소드에 값을 보내기 .. 잘 되기는 하는데 한가지 문제가 ...
114정성태3/19/20059871            답변글 [답변]: [답변]: [답변]: IE에 Docking된 WinFormControl내의 특정 메소드에 값을 보내기 .. 잘 되기는 하는데 한가지 문제가 ...
115김용국3/21/20059280                답변글 [답변]: [답변]: [답변]: [답변]: IE에 Docking된 WinFormControl내의 특정 메소드에 값을 보내기 .. 잘 되기는 하는데 한가지 문제가 ... [1]
119김용국3/22/20059243                    답변글 [답변]: 정상태님 아주 잘 해결 되었습니다.... 감사합니다!
108guest3/17/20059385닷넷 프레임워크 배포
111정성태3/19/20059778    답변글 [답변]: 닷넷 프레임워크 배포
... 91  92  [93]  94  95  96  97