반응형

며칠 전부터 휴가 기간이 되면서 잠시 고향 집에 방문하게 되었다.

오랜만에 뵙는 반가운 가족들, 맛있는 고향의 음식들과 함께 나의 관심을 끄는 작은 문제점 하나가 있었으니, 바로 내가 오래 전에(거의 8년쯤 전) 설치해 둔 와이파이 공유기가 전원 계통이 고장나서 더이상 켜지지 않는 것이었다. 하긴 IEEE 802.11n 표준도 구현되어 있지 않던 값싼 구형의 액세스 포인트를 지금까지 단 한 번도 전원을 끄지 않고 써 왔으니 하드웨어에 문제가 생길 만도 했을 것이다.


집에서는 통신사에 요청해서 무선랜 서비스를 새로 신청해 둔 상태라고 했지만, 내가 방문했던 때는 휴일이라서 당장 와이파이를 쓸 수는 없는 상황이었다. 마침 나는 랩탑을 갖고 있었고, 랩탑에 내장된 와이파이 인터페이스를 사용해서 내가 집에 있는 동안만 임시로 와이파이 AP를 만들면 되겠다고 생각했다.


내 랩탑에는 윈도우 10과 우분투 14.04가 멀티부팅으로 설치되어 있었고, 윈도우에서는 이미 잘 알려진 Connectify라는 어플리케이션을 설치해서 쓸 수는 있었지만 무료 버전의 경우 설정에 제한이 많고 설치되는 윈도우 환경을 더럽히는(?) 듯한 느낌이 들어서 우분투에서 쉘 스크립트로 직접 AP를 만들기로 했다.


AP를 설정하는 방법은 지금 연구실에서 실험으로 쓰고 있는 라즈베리파이 기반의 무선 메쉬 네트워크 환경에서 AP 생성하는 방법만 가져오면 되었기에 금새 완료할 수 있었다. 랩탑에 랜선을 꽂고, 와이파이 인터페이스, hostapd, isc-dhcp-server, iptables를 차례대로 설정해 주었다.


금새 스마트폰에 나타난 새로운 와이파이 액세스 포인트에 동생은 신기해하면서 바로 내가 생성한 와이파이에 접속해서 스마트폰을 쓰기 시작했고, 나는 평소에 연구하던 것이 이럴 때 도움이 될 수 있다는 것이 뿌듯했다.


하지만... 역시 임시로 만든 AP는 어디까지나 임시로밖에 쓸 수 없다는 현실을 체험하는 계기가 되었다. 내가 집에 갔던 첫째날과 다음날까지 내가 랩탑으로 생성한 와이파이 AP를 실제로 써 보면서, 물리적인 무선랜 공유기와의 성능 차이를 몸소 체험할 수 있었다. ㅜㅜ


가장 먼저는 이상하게 랩탑이 자꾸만 인터넷에 한동안 연결을 하지 못하는 문제로 인해서 스마트폰 입장에서는 와이파이에 접속한 상태는 변함이 없지만 갑자기 인터넷이 안 되는 현상이 간헐적으로 일어났다. 그런 문제가 생겼을 때 내가 바로 재부팅으로 해결하는 바람에 원인을 정확하게 파악하지는 못했지만, 재부팅하기 전에 도메인 네임 서버에 ping이 가지 않았던 현상을 통해서 도메인 네임 서버와의 연결이 간헐적으로 끊어졌던 것 같다.

두 번째로는 속도가 그다지 만족스럽지는 못했다. 내가 AP로 설정한 노트북인 삼성 뉴 시리즈9(NT900X3C-A64)이 비록 802.11n을 내장하고 있었고 안드로이드에서도 접속했을 때의 속도가 65Mbps였지만, 실제로는 그 속도가 나오지 않았다. ㅜㅜ 플레이스토어에서 각종 앱을 다운로드 받아서 설치한 적이 있었는데 그 때의 체감속도가 대략 16-24Mbps (1초에 약 2-3MB 정도를 다운로드 받았으므로 bps로 환산하면 대략 이 정도)였다. 동생도 와이파이를 쓰는 동안 좀 느리다고 얘기했던 것을 보면, 제대로 AP 역할을 수행하기 위해서는 HT를 비롯한 좀더 세부적인 설정이나 tweak 등을 해 줬어야 하는 것 같다. 하지만 나는 그렇게까지 자세한 설정을 고치지는 못했고, HT20, HT40 같은 것을 적용해 보려고 노력했지만 결국 실패로 돌아갔다.


결국 이틀간 쓰면서 이전에 고장나기 전까지 쓰던 802.11g보다 오히려 안정적이지 못하고 속도도 별 차이가 없거나 오히려 느리다는 결론을 내릴 수밖에 없었다.

집에 2박 3일 간 머무르는 중에 첫 이틀을 이렇게 내가 랩탑으로 와이파이를 만들어서 쓰고, 마지막 날 아침에는 통신사가 직접 자체 와이파이 공유기를 설치해 주었는데, 그 전용 장비의 체감 속도와 안전성은 확연히 달랐다.


비록 실제로 시중에서 쓰는 공유기들이 랩탑에 비하면 매우 느린 CPU와 아주 적은 양의 메모리를 갖고 있지만, 아무래도 AP 역할을 잘 할 수 있도록 외부로 노출된 안테나를 포함해서 최적으로 설계된 와이파이 네트워크 인터페이스와 그외 여러 측면에서 최적화된 라우터 전용 운영체제와 세부 소프트웨어 설정의 영향을 무시할 수 없는 것 같다. 

결론적으로, 와이파이가 아예 없는 것보다는 랩탑으로 설정한 AP라도 있는 것이 훨씬 나았지만, 전용 하드웨어가 제공하는 와이파이는 그 임시방편보다도 한층 더 좋을 수밖에 없었다. 혹시나 나중에 와이파이 말고도 또다른 연구하던 것을 현실에 써먹어야 할 때에는 꼭 실제 제품과의 차이가 클 수 있다는 것을 염두에 둬야겠다.


반응형
블로그 이미지

Bryan_

,
반응형

무선 메쉬 네트워크에서 멀티홉 라우팅을 하면서, 라우팅을 해야 되는 flow가 아래와 같이 다르면, iptables를 쓸 때에도 필터링을 서로 다른 곳에서 해 주어야 한다:


1) 다른 노드가 source가 되고, 현재의 메쉬 라우터는 중간 노드가 되는 경우

2) (실제로 그럴 일은 별로 없겠지만) 메쉬 라우터 자체에서 패킷이 생성되었을 경우, 즉 메쉬 라우터 자신이 출발지 노드(source)가 돼서 응용 계층으로부터 패킷이 주입되는 경우


특정 포트 또는 목적지로 가는 패킷을 필터링/분류하고 라우팅을 변경하고자 할 때:

- 1번의 경우에는 PREROUTING 단계에서 hook을 걸어야 패킷이 걸린다.

- 2번의 경우는 OUTPUT 단계에 hook을 걸어야 패킷이 걸린다.



<2016.07.17 추가>


내가 하려는 작업은:

  • 멀티홉 라우팅 경로에서 중간노드 역할을 수행하는 라우터가 특정 조건의 패킷에 대하여 마킹을 한다. (--set-mark 옵션)
  • 특정 번호로 마팅된 패킷에 대응하는 별도의 라우팅 테이블을 만들어서 해당 패킷들만을 위한 라우팅 경로를 설정한다.


이 작업을 수행하려면 iptables에서 mangle 테이블을 써야 하고, 이 때 PREROUTING, OUTPUT 체인이 갖는 의미는 참고자료 [1] 에 잘 설명되어 있다.



<참고자료>

[1] http://marcof.tistory.com/35

반응형
블로그 이미지

Bryan_

,