본문 바로가기

반응형

진리는어디에

(289)
소켓 강제 종료시 파이프(pipe) 깨짐 상황 : 서버 프로세스가 떠 있고, 거기에는 수많은(이라고 해봐야 1000개 미만)의 클라이언트 들이 물려 있다. 서버는 select로 read 이벤트를 구분하고, 서버의 listen socket은 blocking이다. 정상적으로 동작하다가 클라이언트(테스트 프로그램으로써 수백개의 connection thread를 생성 시켜 서버로 미친듯이 데이터를 주고 받는 놈)를 강제 종료 하면 항상 그런 것은 아니지만 종종 '파이프 깨짐'이라는 에러를 내고 서버가 종료 된다. 문제 : 프로세스는 종료(그것이 타의든 자의든)를 하게 되면 모든 열려있는 파일디스크립터를 닫게 된다. socket 역시 일종의 파일디스크립터이므로 예외는 아니다. 정상적인 수순을 따르자면 1. client가 죽는다. 2. 모든 열린 파일디스..
Singleton in Multi Thread 들어가며 이번 포스트는 멀티 스레드 환경에서 싱글톤을 사용할 때 흔히 할 수 있는 실수 한가지에 대해서 살펴 보고자한다. 설명을 위해 한가지 상황을 만들어보자. 우리는 지금 부터 싱글톤 이벤트 큐를 만들어야 한다고 가정. 각종 read/write 작업들을 '싱글톤' 이벤트 큐에 집어 넣고, 몇 개의 '스레드'들이 큐를 감시하다, 큐에 새로운 이벤트가 들어 오면 이벤트에 따라 적적한 작업을 해주는 방식인 전형적인 producer/consumer 방식이다. 이 상황에서 중요한것은 '싱글톤'과 몇개의 '스레드'들이다. 그리고 스레드를 만들게 되면 의례 그렇듯이 아래와 같이 레이스 컨디션이 발생하게 된다. 시간 ThreadA ThreadB 1 if(queue.empty()) -> not empty 2 if(qu..
TIME_WAIT state vs SO_REUSEADDR option 아래와 같은 non-blocking socket 서버를 간단하게 나마 제작(말이 non-blocking이지 어차피 read에서 block되기 때문에 non-blocking이라고 하기에 상당히 민망함) #include #include #include #include #include #include #include int main(int argc, char** argv) { if(argc != 2) { std::cout
Edge trigger vs Level trigger 문제 : read가 가능한지를 알아 보기위해 select를 호출 하고 wait time을 NULL로 주어 무한히 대기 하게 했다. 하지만 어찌 된 일인지 아무런 입력이 없을때는 가만히 있다가 한번 입력을 하고 나면 입력 read가 가능 하다는 메시지가 미친듯이 나오기 시작했다. 코드를 잠시 살펴 보자면 아래와 같다. fd_set rset; FD_ZERO(&rset); // 0 은 stdin을 나타낸다. FD_SET(0, &rset); while(1) { fd_set tmp_rset = rset; int state = select(1024, &tmp_rset, &tmp_wset, NULL, NULL); if(state > 0) { for(int fd=0; fd
[C++] const 와 mutable 키워드 이번 포스트는 변수를 상수화 시켜 코드에서 변수의 값을 변경하려고 할 경우 컴파일 타임에 에러를 발생 시키는 const 키워드와 const를 무효화 시킬 수 있는 mutable 키워드에 대해 살펴 보도록 하겠다. C++에서는 절대 변경 되어서는 안되는 변수(변수라는 것 자체가 변경을 할 수 있다는 의미인데 그것을 변경하지 못하게 막겠다는게 개념적으로 아이러니 하긴하지만)에 const라는 한정자를 더해, 변수를 변경하려고 시도 할 경우 컴파일 타임에 감지하여 에러를 발생 시킨다. const 이전에는 #define 전처리 명령어를 이용했지만 전처리 명령어를 이용하는 것은 스코프를 한정 할 수도 없고, 타입에 대한 제약도 없어 여러 모로 실수를 만들 요소를 가지고 있다. 하여 const 키워드 이후 부터는 상..
PHP - 문자열 취급하기(!== 비교 연산자) php는 아주 간편하게 사용할 수 있는 스크립트 언어다. 문법도 C랑 비슷해서 새로 공부해야 할 것도 그렇게 많지는 않다. 하지만 그 간편함 속에 숨겨진 php의 악마성이 있으니... 그것은 바로 문자열과 숫자에 구분이 없다는 것이다!! 먼저 아래의 코드를 보자. 디렉토리에 있는 내용을 단순히 출력 해주는 루틴이다. $dirHandle = opendir("/home/kukuta/") or die("error opendir()") while($filename = readdir($dirHandle)) { echo $filename."\n"; } 정말 간단한 소스다. 디렉토리 내의 파일 리스트를 읽어와 출력한다. 그냥 단순히 읽고 출력하는 것이 전부다. 여기서 오류가 발생 한다는 것이 말이 안된다. 하지만 p..
가변인자를 이용한 함수(va_list) 가변인자 함수 ANSI C 는 인수의 타입이나 개수를 다양하게 취할 수 있는 함수를 선언하기 위해 '가변인자 함수(varages 함수 or variadic 함수)'라는 구문을 정의 하고 있다. 1. 왜 가변인자 함수들이 사용되는가? 원래 C 함수들은 고정된 개수의 인수들을 취한다. 함수를 정의할 때, 인수의 개수와 인수의 데이터 타입을 정의하면 변경이 불가능 하다. '가변인자 함수'는 함수가 호출 될때 마다 인수의 개수를 변경 할 수 있고 타입에 있어서의 변경도 가능하다. 2. 어떻게 가변 인자 함수를 정의하고 사용하는가? 1) #include '가변인자 함수'라는 것을 사용하기 위해서는 'stdarg.h' 헤더 파일이 필요하다. ※ 오래된 C 에서는 'varargs.h'를 사용해서 다양한 개수의 변수를..
SQL command CREATE DATABASE 새로운 데이터베이스를 생성 CREATE TABLE ( schema.. ) 새로운 테이블을 생성 ex) CREATE TABLE tab (val INT); INSERT INTO [(field Name, ... )] VALUES (data, ...) CREATE문으로 생성된 테이블에 데이터를 저장 UPDATE SET = WHERE expr UPDATE 문은 INSERT 문으로 저장되어 있는 데이터 수정 DELETE FROM WHERE expr 테이블에 있는 데이터를 삭제 할때 사용하는 쿼리문 테이블 자체를 삭제하는 DROP과 구분 되어야 한다. ALTER TABLE ADD 테이블에 새로운 필드 추가 ex) ALTER TABLE tableName ADD newFieldName var..
Python 정규 표현식 메타 문자 반복 메타문자 문자 의미 예 * 0 회 이상 반복 ca*t => ct, cat, caat, caaat, … + 1 회 이상 반복 ca+t => cat, caat, caaat … ? 0회 혹은 1회 ca?t => ct, cat {m} m회 반복 ca{2}t => caat {m, n} m회부터 n회까지 반복 ca{2, 4}t => caat, caaat, caaaat >>> import re >>> re.match('cat', 'caat').group() 'caat' >>> re.match('cat', 'cat').group() Traceback (most recent call last): File "", line 1, in ? AttributeError: 'NoneType' object has n..

반응형