한쪽 가슴으로 사랑하기

내 나이 28살,
처음 유방암을 진단 받고 나서 받았던 질문은
"그런데 결혼은 하셨어요?" 아니면 "남자친구는
있으세요?"였다. 그럼 이제 연애는 어떻게 하지?
결혼은? 아기는? 이런 걱정들이 들기 시작했다.
그러던 와중에, 내가 모르는 사이에 사랑이
찾아오고 있었다. 그렇지만 나중에 한쪽뿐인
나의 가슴을 보여주는 것도 두렵고,
혹시나 결혼을 하게 되었을 때
부모님이 반대하실 것도
두렵다.

- 박경희의《한쪽 가슴으로 사랑하기》중에서 -

* 28살 처녀에게 유방암이라니!
청천병력과도 같은 소리일 것입니다.
"한쪽 가슴으로 사랑할 수 있을까?"
절망의 외마디가 가슴을 칩니다.
아무렴요. 사랑할 수 있습니다.
한쪽 가슴이기 때문에 더 뜨겁게,
아픔을 알기 때문에 더욱 깊게,
사랑 할 수 있습니다. 사랑은
모든 살아있는 사람의
특권이니까요.

크리에이티브 커먼즈 라이센스
Creative Commons License
이올린에 북마크하기(0) 이올린에 추천하기(0)

Posted by 홍반장

2010/08/20 13:34 2010/08/20 13:34
Response
No Trackback , No Comment
RSS :
http://tcbs17.cafe24.com/tc/rss/response/5459

일이 사람을 만든다.

도대체 무엇을 위해 일하는가?’
궁금하다면 이것만은 명심해주기 바란다.
지금 당신이 일하는 것은 스스로를 단련하고, 마음을 갈고 닦으며,
삶의 가치를 발견하기 위한 가장 중요한 행위라는 것을...
- 이나모리 가즈오(교세라 명예회장), '왜 일하는가‘에서

이나모리 가즈오 회장과 이야기를 나누던 독일 영사는 이렇게 말했습니다.
“노동은 맡은 일을 달성하는 것이 아니라, 내적 완성을 위한 과정입니다.
일은 그 일에 종사하는 사람의 마음을 연마하고 인간성을 키워줍니다.”
일본 에도시대 이시다 바이간(石田梅岩)의 제업즉수행(諸業修行) 개념과 정확히 일치합니다.
즉 일류국가 국민들은 일은 필요악이자, 힘들고 고통스러운 것이 아닌,
“기술을 갈고 닦아 연마할 뿐 아니라 마음을 수행하는 과정이며,
자아를 실현하고 인격을 높이는 수단”이라는 인식을 공유하고 있습니다.

크리에이티브 커먼즈 라이센스
Creative Commons License
이올린에 북마크하기(0) 이올린에 추천하기(0)

Posted by 홍반장

2010/08/20 13:33 2010/08/20 13:33
Response
No Trackback , No Comment
RSS :
http://tcbs17.cafe24.com/tc/rss/response/5458

모바일 디바이스 환경을 위한

SQLite 성능 향상 테크닉

모바일 환경을 지원하는 디바이스는 휴대성을 고려하기 위해 한정된 자원을 사용해야 하는 많은 제약사항을 가지고 있다. 그러나 똑똑하고 다양한 기능을 지원하기 위해서는 큰 메모리를 사용하고, 다루고자 하는 데이터가 많아지는 경우에는 안정성과 활용성을 고려한 데이터베이스 시스템이 사용되어야 한다. 모바일 디바이스에서 현재 큰 인기를 끌고 있는 SQLite에서 어떻게 하면 성능을 향상시켜 최적의 기능을 이끌어낼 수 있을지 지금부터 살펴보도록 한다.

모바일 디바이스에서 사용되는 데이터베이스 관리 시스템에는 많은 솔루션이 있지만, 그 중에서 대표적인 것이 SQLite이다. SQLite는 구글의 안드로이드나 애플의 아이폰 등에서 사용되는 솔루션으로 사용자 측면과 관리자 측면에서 모두 뛰어난 접근성을 가지고 있다.
SQLite는 다음과 같은 임베디드 시스템을 위한 요구사항을 만족하는 데이터베이스 솔루션이다.

- 사용자가 사용하기 쉬움
- 관리가 간편
- 갑작스런 외부 오류에 둔감
- 다양한 플랫폼에 모두 적용 가능
- 풋-프린트가 작음

SQLite 가 가지는 가장 큰 특성 세 가지는 다음과 같다. 서버를 필요로 하지 않기 때문에 시스템 내에서 별도의 자원을 사용할 필요가 없으며, 다른 솔루션과 달리 설정이 필요 없으므로 사용하기에 편리하다. 또한 트랜잭션 처리가 이뤄지므로, 데이터의 무결성을 보장해 줄 수 있다. 따라서 SQLite는 데스크톱 컴퓨터로부터 PDA, 셀룰러 폰, MP3 플레이어에 이르기까지 많은 디바이스에 적용될 수 있다. SQLite의 주요 특성은 다음과 같다(<표 1> 참조).


이와 같은 특성들을 가지고 있는 SQLite의 내부 구조는 <그림 2>와 같다. 코어, SQL 컴파일러, 백앤드가 주요 핵심요소이고, 이외에 액세서리 역할을 하는 유틸리티와 테스트 코드로 이뤄져 있다.
그럼 지금부터는 SQLite의 성능을 다른 데이터베이스 솔루션과 비교해 보도록 하자. 일단 오픈소스 데이터베이스로서 유명한 MySQL과 비교해 보면 <화면 1>과 같다.

InnoDB를 사용하는 MySQL에 비해서는 SQLite가 빠르지만, MyISAM을 사용하는 MySQL에 비해서는 느린 특성을 가진다.
<표 2>에서는 PostgreSQL과 MySQL의 성능을 SQLite와 비교해 보도록 하자. 비교하는 동작은 INSERT, UPDATE, SELECT, DELETE, DROP이다.
그럼 SQLite의 성능을 최대한 향상시키기 위해서는 어떻게 해야 할까? 우선 다음과 같은 방법을 고려해 볼 수 있다.
SQLite 에서 성능을 향상시키고자 할 때 우선적으로 트랜잭션과 캐시를 고려한다. 만약에 트랜잭션이 명시적으로 선언되어 수행되지 않으면, 각 SQL 문은 자신들의 동작을 보장하기 위해 동작 시마다 새로운 트랜잭션을 가지게 된다. 이는 매번 저널 파일에 대한 열기, 쓰기, 닫기를 수행하도록 함으로써 속도 저하를 유발하므로, 일련의 SQL 문들이 있으면 이 전체를 모두 하나의 트랜잭션으로 묶어 속도를 향상시킬 수 있다.

SQLite 는 저널 파일을 사용함으로써 만약의 동작 실패 시에 트랜잭션을 롤백할 수 있다. 이를 위해 트랜잭션 동작 중에 데이터베이스에서 발생하는 모든 변화들을 기록해야 한다. 따라서 이는 디스크 액세스에 있어서 오버헤드 동작이 된다. 따라서 만약 데이터베이스를 변경할 필요가 없을 경우에는 저널 동작을 수행하지 않도록 한다. 만약에 게임과 같은 애플리케이션이 동작하면서 데이터베이스를 사용하는 경우에는 데이터의 무결성보다는 성능을 더욱 더 중요시하기 때문에 이러한 경우에는 저널링을 중단해도 될 것이다. 물론 사용자가 원한다면 저널링을 수행하도록 한다. 쿼리는 캐시돼 있을수록 디스크에 대한 접근 횟수가 줄어들기 때문에 속도향상에 도움이 된다.
또한 이러한 방법 이외에 추가적으로 SQL 문을 재정렬하거나 인덱스를 생성 및 이용하면 속도를 향상시킬 수 있다. 인덱스를 사용하는 쿼리는 인덱스를 사용하지 않는 쿼리보다 속도의 향상을 기대할 수 있다. 인덱스들 중에 불필요한 것이 있는지는 확인해서 불필요한 것은 제거하도록 해야 한다.
인덱스를 사용하게 되면, 디스크에서 전체 테이블을 스캔하지 않고서도 값의 범위를 선택할 수 있다. 인덱스는 질의가 전체 테이블에 대해 스캔할 필요가 없을 때 속도 측면에서 큰 차이를 가져온다. 인덱스를 사용하기 위해서는 별도의 인덱스 테이블을 생성해야 하기 때문에 부수적인 크기의 오버헤드를 가져온다. 인덱스를 생성하는 방법은 <리스트 1>과 같다.

<리스트 1> 인덱스 생성 방법 CREATE TABLE mytable ( a TEXT PRIMARY KEY, -- index created b INTEGER, c TEXT UNIQUE -- index created );

이러한 방법과 더불어 다음과 같은 방법들도 고려할 수 있다.

첫 번째로 데이터베이스 스키마를 가능한 간단하게 만들도록 한다. 즉, 잘못된 데이터나 논리구조를 가지면 안 된다는 의미다.
두 번째로 데이터베이스 스키마를 무조건적으로 정규화하지 않도록 한다. 이는 개발자에게는 편리할 수 있겠지만, 정규화는 성능을 감소시킬 수 있다.
세 번째로는 SELECT 문에서 테이블의 순서를 조정함으로써 성능을 향상시킬 수 있다.
네 번째로는 불필요한 인덱스들을 사용하는 대신 해시 키를 사용할 수도 있다. 이는 성능문제 때문에 인덱스를 생성하기 어려울 경우에 매우 유용할 수 있다.

또 한, 컴파일러 설정을 확인해서 C 컴파일러에서 최적화 옵션을 사용해 빌드해야 한다. 불필요한 심볼이 들어가서 이를 처리하기 위한 불필요한 동작이 수행되면 성능을 저하시킬 수 있기 때문이다. 만약에 사용하지 않은 특성이 있다면 이는 비활성화시켜서 바이너리 크기를 줄이고, 이를 통해 속도를 향상시키도록 한다.
SQLite의 사용 시간 중에 많은 부분을 차지하는 것은 디스크 액세스 시간이다. 따라서 성능을 최적화시키기 위해서는 디스크 액세스 양을 최소화해야만 한다. 이러한 점을 고려해 다음과 같은 방법을 사용하도록 한다.

- In-memory 데이터베이스 사용
- PRAGMA cache_size 사용
- PRAGMA synchronous=OFF 사용
- PRAGMA count_changes=OFF 사용

이외에도 SQLite의 실제 동작은 파일시스템 위에서 이뤄질 것이기 때문에 하위 근간을 이루는 파일시스템의 성능도 중요한 요소가 된다(<화면 2> 참조).

SQLite 데이터베이스는 기본 값으로 1KB 크기를 가지는 btree 페이지들로 나눌 수 있으며, 데이터베이스를 가지고 동작할 때 이러한 페이지들을 메모리로 로드해 데이터들을 관리한다. 캐시의 페이지 최대값으로 2,000이 기본적으로 설정돼 있지만, 이를 증가시킴으로써 성능 도모를 꾀할 수 있다.
PRAGMA synchronous=OFF를 사용함으로써 디스크에 쓰기 위해 기다리는 시간을 줄일 수 있어 속도를 향상시킬 수 있게 된다. PRAGMA count_changes가 ON으로 설정돼 있으면, 콜백 함수는 각 DELETE, INSERT, UPDATE 동작이 수행될 때마다 수행된다. 따라서 이를 OFF로 해 놓으면 속도를 향상시킬 수 있다.
SQLite에서 GLOB과 LIKE 연산자는 인덱스를 사용하지 않기 때문에 가급적이면 피하도록 한다. 그리고 매우 긴 문자열을 사용할 때 length()를 사용하지 않도록 한다. 따라서 <리스트 2>와 같이 사용하도록 한다.

<리스트 2> Length()의 대체방법 Example : Replace (WHERE length(str)=0) with (WHERE str='').

SQLite 데이터베이스의 파일 크기를 줄이기 위해서는 실제로 내용이 없어서 비어 있지만 메모리 페이지를 차지하는 페이지를 제거하는 방법을 우선적으로 사용할 수 있다. 이를 위한 가장 간단한 방법은 VACUUM이라는 명령어를 사용하는 것이다. 이는 <리스트 3>과 같이 수행할 수 있다.

<리스트 3> VACUUM 사용 방법 (C 코드에서) sqlite_exec(db, "VACUUM;", 0, 0); (sqlite의 유틸리티) sqlite> VACUUM; (쉘 프롬프트에서) $ echo 'VACUUM;' | sqlite filename

데이터의 크기를 최소한으로 만들기 위해서 압축하는 방법을 사용할 수 있다. 바이너리 데이터를 압축 및 해지하기 위해서 sqlite_ encode_binary()와 sqlite_decode_binary() 함수를 사용할 수 있다. 이를 통해 저장하기에 적합한 바이너리로 인코딩할 수 있다. 만약에 특수 문자를 포함하지 않는다면, 모든 0을 제거하기 위해 XOR 인코딩을 사용할 수 있다. 이러한 인코딩 방식과 별도로 7-비트 데이터 인코딩 방식이 존재한다. 이는 상위 비트를 토글링함으로써 SQL 문을 인코딩하는 데 유용하게 사용될 수 있다.

<리스트 4> 7-비트 데이터 인코딩 방식 int ascii7enc(char *out, const char *in, int len) { int ct = len; if (!in || !out || len < 0) return -1; while (ct-- > 0) { char ch = (*in == 0 || *in == '\'' || *in == 0x80 || *in == '\''^0x80)? (*in++ ^ 0x80): *in++; *out++ = ch; } return len; }

지금까지 SQLite 성능을 향상시키기 위한 여러 가지 방법을 살펴봤다. 다양한 방법을 통해 성능을 향상시킬 수 있지만, 어느 하나만을 사용한다고 해서 혁신적으로 속도가 향상되는 것은 아니다. 따라서 해결법을 혼합 사용해 원하는 속도의 향상을 이뤄내도록 노력해야 할 것이다.


필자소개

김형훈 asinayo73@hotmail.com|모바일 디바이스의 설계부터 테스팅까지 모든 부분에 관심이 많으며, 현재 gmobileTech사에서 모바일 디바이스 구조검증 및 설계 컨설팅 업무를 맡고 있다. 다양한 형태의 모바일 디바이스가 어떻게 하면 각각 최적의 성능을 낼 수 있는지에 대해 연구하고 있다.

출처 : 한국 마이크로소프트웨어

제공 : DB포탈사이트 DBguide.net

크리에이티브 커먼즈 라이센스
Creative Commons License
이올린에 북마크하기(0) 이올린에 추천하기(0)

Posted by 홍반장

2010/08/19 13:17 2010/08/19 13:17
, ,
Response
No Trackback , No Comment
RSS :
http://tcbs17.cafe24.com/tc/rss/response/5457

가끔 떠나라.
떠나서 잠시 쉬어라.
그래야 다시 돌아와서 일할 때
더 분명한 판단을 내리게 될 것이다.
쉬지않고 계속 일을 하다보면 판단력을 잃게 되리니

조금 멀리 떠나라.
그러면 하는 일이 좀 작게 보이고
전체가 한눈에 들어오면서
어디에 조화나 균형이 부족한지 더욱 자세하게 보일 것이다.

인류역사상 가장 창의적인 인물로 평가받는 레오나르도 다빈치의 글입니다.
가끔은 일과 거리를 둘 때 우리는 어떤 신성한 힘 (Divines intervention)에 이끌려
더욱 창조적으로 일할 수 있다는 것입니다.
바빠서 휴가 가실 엄두를 내지 못하신 분들,
바쁘니깐 휴가를 꼭 한번 가보시기 바랍니다.
크리에이티브 커먼즈 라이센스
Creative Commons License
이올린에 북마크하기(0) 이올린에 추천하기(0)

Posted by 홍반장

2010/08/19 13:12 2010/08/19 13:12
Response
No Trackback , No Comment
RSS :
http://tcbs17.cafe24.com/tc/rss/response/5456

마음이 편하고 기분이 좋으면
기가 막힘없이 흐르고 몸에 밝은 기운이 가득
차는 것을 느낄 수 있었다. 마음이 불편하고
우울할 때에는 기가 어딘가 막히는 것 같고
몸의 기운도 어둡고 차가운 듯 느껴졌다.
그러면서 모든 육체적인 병은 마음에서
비롯된다는 확신을 얻게 되었다.


- 이남순의《나는 이렇게 평화가 되었다》중에서 -


* 마음이 먼저입니다.
마음에 따라 기분이 달라집니다.
기가 막히거나 흐르고, 몸이 좋아지거나
나빠집니다. 그래서 '마음공부'가 필요합니다.
자기 마음을 다스리는 것이 몸을 다스리고,
세상을 다스리는 것입니다.
마음이 먼저입니다.
크리에이티브 커먼즈 라이센스
Creative Commons License
이올린에 북마크하기(0) 이올린에 추천하기(0)

Posted by 홍반장

2010/08/19 13:11 2010/08/19 13:11
Response
No Trackback , No Comment
RSS :
http://tcbs17.cafe24.com/tc/rss/response/5455


# 암호 변경

mysql> UPDATE user SET  password = pawssword('new_password') where user = 'userid';
mysql> FLUSH privileges;

# 사용자 추가

mysql> INSERT INTO user(Host, User, Password) VALUES('localhost', '유저명', password('new_password'));
mysql> FLUSH privileges;

# 데이터베이스 추가 및 권한 주기

mysql> GRANT ALL privileges ON 데이터베이스명.* TO 유저명@localhost IDENTIFIED BY '유저패스워드';
mysql> FLUSH privileges;


크리에이티브 커먼즈 라이센스
Creative Commons License
이올린에 북마크하기

Posted by 홍반장

2010/08/18 16:46 2010/08/18 16:46
, , ,
Response
No Trackback , No Comment
RSS :
http://tcbs17.cafe24.com/tc/rss/response/5454

나는 생각했다.
희망이란 것은 있다고도 할 수 없고, 없다고도 할 수 없다.
그것은 마치 땅 위의 길이나 마찬가지다.
원래 땅 위에는 길이란 게 없었다.
걸어가는 사람들이 많아지면 그게 곧 길이 되는 것이다.
– 루쉰 소설 ‘고향’의 맨 마지막 구절

이글을 본 제주 올레 서명숙 이사장은
“그렇다. 걸어가는 사람들이 많아지면 그게 곧 길이 되는 법이니,
일단 내려가서 길을 만들자.
그리고 그 길이 진정 길이 되도록 사람들을 불러들이자!”라고 결심하고
‘인간이 인간답게 존중 받으면서 걷는 평화롭고 아름다운 올레 길’을
만들기 시작했다합니다.

우리의 희망과 새로운 길은 ‘지금, 여기에서’ 나의 다짐과 실천에서 비롯됩니다.
크리에이티브 커먼즈 라이센스
Creative Commons License
이올린에 북마크하기(0) 이올린에 추천하기(0)

Posted by 홍반장

2010/08/18 09:42 2010/08/18 09:42
Response
No Trackback , No Comment
RSS :
http://tcbs17.cafe24.com/tc/rss/response/5453

'저 큰 나무를 봐'

저 큰 나무를 봐
우리가 관계를 맺는다는 건
나무에서 떨어진 씨앗 하나가
작은 나무가 되는 일이야
작은 나무가 자라서 우리에게 그늘 주는
저 큰 나무가 되는 일이야

한 번에 큰 나무는 절대 만들어질 수 없지
때에 맞게 마음 주고 말을 나누며
작은 잎새 올라오면 깊은 눈빛도 건내주며
시간이라는 거름이 알맞게 주어지면
우리의 만남도 언젠가는 큰 나무로 자라겠지


- 이정숙의 시집《길을 떠나면》에 실린 시 <큰 나무를 믿다> 중에서 -


* 아무리 우람하고 큰 나무도
작은 잎새, 작은 묘목에서 시작됩니다.
아닙니다. 작은 씨앗 하나에서 비롯됩니다.
우리의 만남, 우리의 인연, 우리의 관계도 그러합니다.
지금은 비록 작은 씨앗, 작은 나무이지만 머지않아
하늘을 가리는 큰 그늘의 나무로 자랄 것입니다.
보십시오! 아직은 작지만 우리 안에서
잘 자라고 있는 저 큰 나무를!
크리에이티브 커먼즈 라이센스
Creative Commons License
이올린에 북마크하기(0) 이올린에 추천하기(0)

Posted by 홍반장

2010/08/18 09:42 2010/08/18 09:42
Response
No Trackback , No Comment
RSS :
http://tcbs17.cafe24.com/tc/rss/response/5452

유저스토리북 - http://userstorybook.net/
트윗믹스 - http://tweetmix.net/
유저스토리랩 - http://www.userstorylab.com/
책이야기 - http://read.userstorybook.net/

과연 어떤 서비스인것가?

사용자 삽입 이미지사용자 삽입 이미지사용자 삽입 이미지
사용자 삽입 이미지사용자 삽입 이미지





크리에이티브 커먼즈 라이센스
Creative Commons License
이올린에 북마크하기(0) 이올린에 추천하기(0)

Posted by 홍반장

2010/08/17 18:55 2010/08/17 18:55
, , ,
Response
No Trackback , No Comment
RSS :
http://tcbs17.cafe24.com/tc/rss/response/5451

남보다 더 공부하라


내가 자랄 때만 해도 ‘밥 남기지 마라. 중국아이들은 굶고 있어’라는
어머니의 말씀을 들었지만,
나는 지금 딸아이에게 이렇게 말한다.
‘더 열심히 공부해라. 중국과 인도 아이들이 네 직업을 넘보고 있어.’
- 토머스 프리드먼

경영의 구루, 톰 피터스의 신작 ‘리틀 빅씽’에 나오는 이야기입니다.
톰 피터스는 이렇게 외칩니다.
“공부하라. 정말 공부하라.
27세도 공부하고 47세도 공부해야 한다.
나처럼 내일 모레 칠순인 사람도 공부해야 한다.
공부하라!”
크리에이티브 커먼즈 라이센스
Creative Commons License
이올린에 북마크하기(0) 이올린에 추천하기(0)

Posted by 홍반장

2010/08/17 09:29 2010/08/17 09:29
Response
No Trackback , No Comment
RSS :
http://tcbs17.cafe24.com/tc/rss/response/5450

« Previous : 1 : ... 98 : 99 : 100 : 101 : 102 : 103 : 104 : 105 : 106 : ... 639 : Next »

블로그 이미지

- 홍반장

Archives

Recent Comments

  1. 1 pHqghUme 01/05
  2. 1 pHqghUme 01/05
  3. 1 pHqghUme 01/05
  4. 1 pHqghUme 01/05
  5. 1 pHqghUme 01/05

Calendar

«   2025/01   »
      1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31  
Statistics Graph

Site Stats

Total hits:
257787
Today:
348
Yesterday:
431