반응형

작년(2016년) 이맘때쯤에 연구를 하다 말고(ㅜㅜ) 구글 코리아에 지원을 했다가 떨어졌었다. 벌써 1년이나 지났다.


구글 채용 절차는 서류전형(온라인으로 CV 보내는 게 전부), 전화 일반면접(대화와 질의응답), 전화 코딩면접, 현장면접, 입사의 순서인데, 작년에 지원하던 당시에 나는 전화 코딩면접만 두 차례 겪어보고 떨어졌다. 기왕 떨어지더라도 현장면접까지는 가 봤어야 하는데, 내가 현장면접을 할 정도의 실력이 되지 못했다는 반증이니 달리 할 말이 없다. ㅠㅠ 그래서 현장면접에서 어떻게 해야 하는지에 대해서는 한 마디도 쓸 수 없다. 나중에 혹시 또 지원하게 되면 + 현장면접까지 겪어볼 수 있게 된다면 그 때 추가하는 걸로

 

비록 1년 전의 일이지만 그 당시의 경험을 따로 어딘가에 기록해 두지 않았기에, 여기에 기록하면서 앞으로 professional (우리말로 딱 표현하려니 잘 떠오르지 않는다)한 소프트웨어 엔지니어 또는 연구원이 되기 위해서 어떤 노력을 해야 할 지 생각을 정리해보려 한다.

 

일단 구글의 소프트웨어 엔지니어 채용 스타일은 굳이 쓰지 않더라도 잘 알려져 있고, 유튜브에는 구글 코리아가 올린 현장면접 예시 영상도 있다. [1] 게다가 최근 구글의 채용 스타일을 꽤 많은 IT 대기업들이 따라 하고 있다. LG전자 CTO의 소프트웨어 직군 면접의 일부도 그랬었던 기억이 있다.

 


*지원부터 전화면접까지의 과정 개요


나는 링크드인에서 구글 코리아 소프트웨어 엔지니어 지원 페이지에 CV를 보냈는데(링크드인 프로파일을 CV로 변환해서 첨부함), 서류 통과 후에 구글 재팬(?)에서 영어로 면접을 보자는 메일이 왔다. 그래서 전화상으로 대화를 하고 질의응답을 하는 면접은 구글 재팬에서 일하는 소프트웨어 엔지니어와 영어로 진행했다. 지원대상은 구글 코리아였는데 왜 구글 재팬에서 연락이 왔는지는 잘 모르겠다. 그냥 어느 branch에 가던지 상관 없이 회사 전체적인 입장에서 면접 가능한 엔지니어를 배정한 것인지, 아니면 일본 branch에서 실제로 관심이 있었는지는 알 수 없다.

 

전화상의 코딩이 아닌 일반면접 후에 전화 코딩면접을 할 때에는 다행히도 구글 코리아에서 한국인 소프트웨어 엔지니어가 전화를 걸어 와서 한국어로 편하게(?) 면접을 진행할 수 있었다.


전화 코딩면접은 두 번을 했는데, 사실 전화 코딩면접은 한 번만 하고 당락을 결정하는 게 일반적인 듯 하다. 내가 왜 전화 코딩면접을 두 번 했는지 정확한 이유는 사실 알 수 없다. 굳이 추측하자면, 내가 첫 번째 전화면접 후에 당락의 경계선 상에 놓이게 되면서 현역 엔지니어들이 보기에 긴가 민가해서(…) 한 번만 더 기회를 줘 보자고 생각했을 지도 모르겠다.

아니면 조금 더 부정적으로 보자면, 내가 비록 첫 번째 전화면접에서 망했지만(ㅠㅠ) 그럼에도 불구하고 혹시나 지원자가 애석하게도 문제가 잘못 걸려서 못했을 지도 모르니 다른 문제를 내서 한번 더 역량을 발휘할 기회를 줘 보자는 생각이었을 수도 있다. 결국 두 번째 전화면접 이후에 다시 구글 재팬에 있던 맨 처음 전화로 얘기했던 엔지니어로부터 탈락 통보를 이메일로 받았다.

 

전화 코딩면접 진행 과정은 잘 알려져 있듯이 사전에 이메일로 공유된 구글 문서를 켜고, 휴대폰으로 걸려오는 전화를 통해서 문제를 전달받고, 30분 동안 그 문제를 해결하는 코드를 구글 문서에 작성한다. 중간에 엔지니어와 계속 전화상으로 대화하면서 진행한다.

 

첫 번째 전화 코딩면접 때는 문제를 정확하게 이해하지 못하는 바람에 알고리즘 제시는 못했고, 어찌됐든 컴파일 에러나 로직 에러(스택오버플로우, 익셉션 따위) 없이 돌아가는 코드를 제출하기는 했다.

두 번째 전화 코딩면접 때는 문제를 제대로 이해했고 어떻게 해결하면 되는지 해결 방법도 개념상으로는 맞게 제시했지만, 막상 내가 짠 코드에 컴파일 에러뿐만 아니라 스택오버플로우 문제마저 있는 상태로 제출해 버렸다. ㅠㅠ

(문제가 무엇인지는 왠지 함부로 공유하면 안될 것 같아서 일부러 언급하지 않았다.)

 

 

위의 두 차례의 전화 코딩면접을 겪으면서 나의 어떤 부분이 부족했는지를 생각해 보았다.

 

*알고리즘과 코딩실력: 두 마리 토끼 모두 잡기


위에 언급했듯이 나의 첫 번째와 두 번째 코딩면접 결과를 보면 알고리즘 이해도코드의 완성도, 이 두 가지 측면에서 서로 다른 한계를 갖고 있었다. 알고리즘을 정확히 이해해서 문제 해결방법을 제대로 짚기도 해야 하지만, 결국 그걸 주어진 시간 안에 집중적으로 코딩해서 실제로 돌아가는 코드를 만들어내는 능력이 있는지도 같이 검증하는 것이 아닐까 싶다.

구글 입장에서도 이익을 극대화하려면 같은 소프트웨어 엔지니어라도 기본기가 있어서 재교육 비용이 가급적 적게 드는 인재를 원할 테니까 당연한 것일 수 있다. 면접 과정에서 프로그래밍 언어의 선택권이 지원자에게 있는 만큼, 그만큼 지원자 입장에서 가장 자신있는 프로그래밍 언어를 들고 왔을 테니 적어도 문제없이 코드를 짤 수 있어야 한다는 전제가 깔려 있을 것 같다.

 


*코딩면접 이전의 일반 전화면접의 중요성


이 부분은 이전 포스팅(http://skylit.tistory.com/189)에서도 썼지만, 채용에서 떨어진 후에 다시 생각하면서 반복해서 쓰게 되었다.

지금 다시 생각해 보면, 전화 코딩면접을 하기 전에 구글 재팬 소프트웨어 엔지니어와 나눴던 대화가 의외로 중요했으리라는 생각이 든다. 그 당시에 나 자신의 역량에 대해서 여러 분야별로 1~10점 사이의 점수를 매겨 보라는 질문을 받았는데, 그 때 멋모르고 Java 언어를 조금 높게(7) 제시했더니 엔지니어가 살짝 당황하는 눈치였다. 그리고 이어서 들어오는 Java 언어의 자세한 속성들에 대한 질문에서 제대로 대답하지 못하고 실컷 털리고 보니 내가 점수를 뻥튀기한 셈이 되어 버렸다. ㅜㅜ

그리고 알고리즘은 내가 4점 또는 5점이라고 대답했던 것 같다. 이 경우는 비록 그 당시에 대답하던 당시에는 나의 가감없는 실제 실력을 그대로 보여주는 점수라고 할지라도, 차라리 그 전에 미리 알고리즘 개념을 복습을 좀 하고서 6점 정도가 된다고 자신 있게 이야기할 수 있어야 했다. 알다시피 구글은 알고리즘을 특히나 중요하게 생각하는데 이미 그 역량에서 내가 한 수 접고 들어간 것이다. ㅜㅜ

, 코딩이 아닌 일반 전화면접이고 그냥 대화를 나눈다는 식으로 안내가 오더라도 그 메일에 속지 말고(?) 전산학의 주요 분야를 충분히 복습해야 한다.

 


*트렌드보다는 기본기가 충실한 것이 더 중요하다.


IT분야의 큰 트렌드에 따라 시기별로 회사가 유난히 원하는 소프트웨어 엔지니어의 종류도 어느 정도 있게 마련이다. 가령 2000년대 중후반에는 정보검색 기술, 2010년대 초반에는 빅데이터, 수 년 전부터 지금까지는 IoT와 클라우드, 최근에는 인공지능 등

그런데 구글은 일반 소프트웨어 엔지니어 채용 과정에 있어서는 그런 트렌드를 별로 고려하지 않는 듯한 느낌이 들었다. (트렌드에 적합한 실력 있는 인재는 그 회사를 인수하는 방법으로 충당하는 것일지도?)

내가 얼마나 지금의 트렌드에 적합한 인재인지에 대한 자기PR은 서류 전형에서 조금이나마 영향을 줄 수는 있을 지도 모른다. 하지만 전화 코딩면접에서는 정말 내가 학사인지 석사인지 박사인지는 전혀 중요하지 않았고, 내가 석/박사과정을 하면서 나름대로 확보했다고 생각되는 경쟁력에 대해서는 통화를 시작할 때 단 한번 물어보고 끝났다. 예를 들면,

 

첫 번째 전화 코딩면접 당시:

엔지니어: 지금 박사과정 하면서 어떤 연구를 하고 있죠?

: , IoT 서비스 플랫폼을 개발하고 그 중에서도 무선 네트워킹을 서비스 종류별로 효율적으로 해주기 위해서 블라블라~~~ … (1분 뒤)


엔지니어: , 잘 알겠습니다. 자 그럼 문제를 내도록 하죠.

: ……

 

두 번째 통화에서도:

엔지니어: 최근에 연구하면서 무엇을 개발했나요?

: , 라즈베리파이와 일반 가전기기를 연동해서 스마트한 IoT 기기로 만들고 그들을 서로 연결해서 블라블라블라~~ (1분 뒤)


엔지니어: 그 과정에서 무엇이 가장 어려웠나요?

: (오 의외로 다른 질문이!) 

: , IoT 기기들을 실제로 회의실, 휴게실 같은 공간에 설치하고 IoT 소프트웨어 플랫폼 올리고 우리만의 스마트 기기 코드를 짜서 올려서 돌아가게 만들 때 블라블라블라~~ (1분 뒤)


엔지니어: , 알겠습니다. 그럼 문제를 내겠습니다.

: …… (ㅠㅠ)

 

결론적으로, 구글은 나의 석/박사 연구주제나 논문에 관심이 없다. ㅠㅠ /박사과정을 통해서 습득한 연구능력이 산업 현장에서 일어나는 문제를 제대로 정의해서 해결 방법을 체계적으로 제시하는 것으로 발현이 되는지를 코딩면접을 통해서 검사할 뿐이다. , 내가 과거에 석/박사 연구를 얼마나 체계적으로 잘 수행했는지를 확인하는 대신, 그렇게 연구를 잘 했으니까 instant하게 주어지는 문제 상황에 대해서도 본인이 잘 대처하는지 증명해 보라는 식이다.

 

해외, 국내를 막론하고 차라리 다른 회사들이라면 나의 박사학위 연구 주제에 대해서 물어볼 만도 하고, 어느 학회나 저널에 냈는지에 관심을 가져 주거나 연구실에서 수행한 프로젝트가 회사가 필요로 하는 일과 얼마나 연관성이 높은지 정도를 생각해볼 만도 한데, 구글 소프트웨어 엔지니어는 그런 거 없다. 그냥 소프트웨어 엔지니어 개인이 기본기와 문제해결능력이 충분하면 어떤 문제를 던져 줘도 잘 해결할 것이라는 단 하나의 원리만 갖고서 채용하는 것처럼 느껴졌다.

물론 구글도 개발이 아닌 연구 부서가 없을 리가 없겠지만 잘 알려져 있지 않으니까적어도 구글이 생각하는 소프트웨어 엔지니어 범주에서는 학위를 별로 신경쓰지 않는 것만은 확실하다.

 

이것을 바꾸어 생각해 보면, 결국 내가 석/박사과정을 충실하게 보냈는지를 과거 기록에 의존하지 않고 검증하는 것과 같다. 모든 교수님들이 얘기하듯이 대학원에서 배우는 핵심은 문제 정의와 문제 해결 능력이고, 이것은 스펙만으로 일대일 대응으로 증명되지는 않는다. , 문제해결능력이 뛰어난 석/박사가 논문을 잘 쓰고 프로젝트를 성공적으로 수행하는 것은 참이 되지만, 좋은 논문실적과 좋은 프로젝트 수행 실적이 개인의 문제해결능력을 역으로 증명해 준다고 볼 수는 없다는 것이다.

 


*결론: 어려운 문제를 대하는 태도의 문제


비록 전화 코딩면접에서 떨어졌지만, 내 입장에서는 꽤 중요하고 값진 경험이었다. 내가 알고리즘 설계와 코딩 실력이 어느 정도 되는지를 점검할 수 있는 기회였고, 한편으로는 말로 설명하는 나의 역량과 실제로 드러나는 나의 생산성 사이에 존재하는 괴리를 직접 확인할 수 있었다.


최근에 자꾸 연구과제 등 신경쓸 것이 많다는 핑계로 개인연구가 점점 미뤄져 가는 현실을 한탄하고 있지만, 정작 이러한 도전적인 상황에서 문제해결능력과 코딩면접 때와 같은 집중력으로 지금의 상황을 돌파해 내지 못하는 내 모습을 다시 확인할 수 있었다. ㅜㅜ 내가 박사학위를 내 손으로 내 실력으로 받기 위해서는 지금의 내 모습에서 한두 단계는 더 역량을 업그레이드해야 한다는 것도 다시 느끼게 되었다.


개인연구에서 제시하는 문제 상황을 시뮬레이션이나 실험 코드로 구현해서 측정하고 그걸 증명하는 과정에서 쉽게 코딩이 되지 않을 때가 자주 있는데, 사실 그 때 문제를 해결하는 것이 어쩌면 구글 전화 코딩면접을 하는 과정과 다를 바가 없는 것 아닐까? 어려움에 봉착했을 때, 귀찮아하면서 좀더 쉬운 과제 문서작업이나 연구실 허드렛일들(서버 관리 등)을 하며 의도적으로 회피했던 내 모습이 부끄럽다. 그럴 때 문제에 직면해서 해결 방법을 설계하고 그 방법을 집중해서 구현하면서 (비록 에러가 나거나 버그가 발생하더라도) 반복적으로 검증함으로써 점차 나만의 문제 해결 능력과 코딩 능력을 쌓아 가는 태도가 필요하다.


무턱대고 방향성 없이 하는 노력이 아니라, 나의 궁극적인 목표(박사학위)를 달성하는 과정에서 일어나는 온갖 문제들을 어떻게 해결할 지를 생각해 가면서 꾸준하게 집중적으로 노력하는 나 자신이 완성될 때까지는 힘들지만 매일매일 회피하지 말고 노력해야 하겠다.


 

<참고자료>

[1] https://www.youtube.com/watch?v=BF3FLDAzWxo


반응형
블로그 이미지

Bryan_

,
반응형


역시 뭘 해도 정부/공기관 사이트가 가장 말썽이다.


안 그래도 일반 사기업 웹사이트에서도 불편한 온라인 결제 또는 공인인증 관련된 작업이 정부 사이트에서는 문제가 몇 배로 증폭되는 경우를 쉽게 볼 수 있다.

여기서는 그 여러 경우들 중에서 우체국 쇼핑몰의 사례를 설명한다.



*발단: 우체국에서 쇼핑을 하고 싶을 뿐인데...


아내가 집 컴퓨터(윈도우 10)에서 우체국 쇼핑(http://mall.epost.go.kr)에서 대추차를 사려고 했는데, 크롬 브라우저에서도 실패하고, 인터넷 익스플로러에서도 마찬가지로 결제가 안돼서 주문을 실패했다고 한다. 그러면서 나한테 사이트 링크를 보내 주면서 대신 좀 결제해 달라고 요청을 해 왔다.


이 때까지만 해도 나는 그래도 플러그인 설치가 좀 많을 뿐이지 문제없이 잘 될 거라 생각하고, 연구실 PC에서 크롬 브라우저를 통해 우체국 쇼핑몰에 들어가 보았다.



*문제의 시작


일단 맨 처음 우체국 쇼핑몰 사이트에 들어가면 내가 어디서 무엇을 하던지 관계없이 다짜고짜 nProtect Online Security 1.0부터 설치를 강요한다. 이미 내 PC에는 금융권 사이트를 방문하기 때문에 nProtect Online Security가 설치되어 있지만 그런 것은 전혀 상관없다. 무조건 설치해야 한다.

사실 nProtect 자체를 설치하는 과정에서는 문제가 일어난 적은 없었기에, 군말 없이 그냥 설치했다. 설치를 거부하고 맞서 봐야 웹페이지가 더 진행되지도 않을 테니 얻을 수 있는 이득도 없고...



본격적인 문제는 "결제"를 진행할 때부터 일어났다. 일단 상품 페이지에서 결제하기 버튼을 눌렀더니, 이제 크롬에서는 NPAPI를 지원하지 않기 때문에 결제를 할 수 없다는 안내가 뜬다.




그래, 그럴 수 있다.

저기 최상단에 표시되는 KG Inicis 로고만 봐도 알 수 있다.


KG Inicis도 간편결제 서비스가 있겠지만, 아마 우체국 쇼핑몰에 붙어 있는 것은 액티브X 같은 플러그인 방식이니까 저런 경고가 떴겠지. 만약 결제 옵션이 정말로 카드결제밖에 없었다면, 저 안내 메세지는 사실이고 나는 선택의 여지 없이 인터넷 익스플로러를 썼을 것이다. 



하지만...


하지만 아이러니하게도, 주문 페이지의 맨 아래쪽에 가 보면 저 경고 메세지와 아무런 관련이 없는 "간편결제" 옵션이 그것도 한두 개도 아니고 다섯 개나 있다.


(우체국 쇼핑몰에서 2017년 3월 현재 지원하는 간편결제 옵션들.)



아니 왠일로 우체국 쇼핑몰에서 간편결제를 다섯 개나 지원하는 것일까? 

나는 간편결제가 단 한 개도 없을 줄 알았는데, 저 정도면 꽤 잘 해주는 거잖아?

그러면 우체국 쇼핑몰이 간편결제의 본래 목적과 의미를 알고 있는지 의심이 가기 시작한다. 


간편결제는 운영체제나 브라우저, 플러그인에 상관 없이 어디서나 문제없이 동일한 방법으로 결제하기 위해서 나온 개념이다. 윈도우를 쓰든, 맥OS를 쓰든, 리눅스를 쓰든, 심지어 스마트폰 OS에서도 아무 웹브라우저나 켜서 결제를 진행해도 문제없이 잘 되어야 간편결제다. 따라서 간편결제에서는 크롬 브라우저가 NPAPI가 되고 말고가 상관이 없어야 하는 것이다. 그런데 우체국 쇼핑몰은 결제 옵션에서는 간편결제를 걸어 놓고, 팝업창에서는 크롬에서 더이상 결제할 수 없다는 이율배반적인 안내를 하고 있다. 


우체국 쇼핑몰에서 "신용카드(일반)" 또는 "휴대폰결제" 같은 옵션을 선택했을 경우에는 저 경고가 유효했을 텐데 그걸 선택적으로 표시하지 않고 일단 무조건 경고창이 뜨도록 웹페이지를 잘못 만든 것은 아닐까 하고 추측해 본다.



*비극의 정점


일단 간편결제 옵션이 있고 간편결제 본래의 목적을 믿으니까, 나는 위의 팝업 경고를 무시하고 결제를 진행해 보기로 했다. 마침 계정을 가지고 있는 "시럽페이"를 선택하고 "결제하기" 버튼을 눌렀더니...


(윈도우10, 크롬 브라우저에서 "시럽페이" 간편결제를 진행하고 나서 표시된 먹통 상황)


...역시 헛된 기대를 했던 것일까?

시럽페이 결제를 진행하는 팝업 페이지까지는 떴는데, 그 뒤로 더는 진행하지 못하고 결국 크롬은 먹통이 되었다.

저 화면에서 팝업창을 종료하고, 크롬 브라우저 창까지 종료 버튼을 눌렀는데 거의 10여 초를 넘게 기다리고 나서야 종료가 되는 것이었다.


...하지만 여기서 끝이 아니었다. 이렇게 결제만 실패하고 상황이 종료되면 그나마 다행이었을 것이다. 이후로 윈도우10은 거북이마냥 대부분의 명령에 반응을 한참 느리게 하기 시작했고, 심지어 "작업 관리자"는 아예 실행조차 되지 않았다. 분명히 우체국 쇼핑몰에서 결제하기 전까지는 멀쩡하던 컴퓨터가 위와 같이 결제 시도를 한번 하고 나서는 아주 못 쓸 상태가 되고 말았다.


결국 재부팅하기로 결정하고 윈도우10에서 시스템 재시작을 시켰는데, 그마저도 되지 않는 것이었다. "다시 시작하는 중" 화면만 10분이 지나도록 바뀌지 않는 상황을 겪고 나서, 결국 본체의 Reset 버튼을 눌러야만 했다. 리셋 버튼을 누르는 행위가 PC 하드웨어에 무리를 줄 위험이 있다는 것은 말하지 않아도 누구나 알고 있을 것이다.


분명히 말하지만 내 PC는 우리은행, 국민건강보험 사이트 외에는 들어가서 뭔가 설치한 적이 없는 꽤나 청정한(?) 상태였고, 오피스나 개발환경 외에 특별한 프로그램이 설치되어 있지도 않은 상태였다.


...이렇게 내 연구실 PC는 만신창이가 되었다.



(시럽페이 소개 페이지의 일부.

간편결제는 위와 같이 아무 데서나 잘 되니까 간편한 것이다.)




*간편결제도 간편하지 않게, 이것이 정부의 능력?


정말 여러가지 의미로 대단하다.

일개 사기업의 간편결제 따위는 정부 앞에 아무 것도 아니라는 것을 보여주기라도 하듯이, 간편결제도 불편하게 만드는 공기업의 능력이 참 대단하다.

개인 쇼핑몰만도 못한 안정성을 개선할 생각은 없고, 모든 사용자를 강제로 인터넷 익스플로러를 쓰도록 해서 군말없이 위에서 시키는 대로나 하라는 경직된 문화가 어쩜 이렇게 온라인 상에서도 예외 없이 일관되게 나타나는지 참 대단하다.




*인생사 새옹지마?


윈도우 PC가 재부팅되기를 기다리는 동안, 혹시나 해서 연구실에서 쓰고 있는 우분투(Ubuntu; 리눅스 운영체제의 한 종류)에서 우체국 쇼핑몰을 방문해 보았다. 정말로 아무런 기대를 갖고 있지 않았다. 그냥 못 먹는 감 찔러나 보는 심정이었다.




...어?


원래 윈도우 PC에서는 일단 방문하자마자 nProtect Online Security부터 설치하라고 시키더니 여기서는 아무 것도 뜨지 않는다. 로그인을 하는 동안에도 아무 문제가 없었다.


일단 사려고 했던 대추즙 주문 페이지까지 가 보았다.

크롬에서 NPAPI 때문에 결제할 수 없다는 경고창조차 뜨지 않았다. (?!)

갑자기 기대감이 생겨서 시럽페이를 선택하고 결제하기 버튼을 눌렀더니...



...어? (2)


여기서부터는 윈도우 PC의 크롬 브라우저에서는 안되던 것인데 결제가 계속 문제없이 진행이 되는 것이었다.


(우분투에서 시럽페이를 통해 우체국 쇼핑몰 결제가 완료된 화면)


...어? (3)


결국 우분투에서 결제까지 문제없이 완료했다.


...

......

..........

...뭐지 이 이상한 기분은?


윈도우에서는 페이지 하나 넘어가기도 힘들고 PC가 통째로 먹통이 되는 그 난리통에, 거의 기대할 수 없는 다른 운영체제에서 아무 문제없이 간편결제 본연의 기능을 써서 결제를 성공하다니. 그것도 공공기관 사이트에서?


굳이 이유를 알 필요가 있겠냐마는, 추측해 보자면 윈도우가 아닌 다른 운영체제에 대해서 예외처리를 해 주지 않았기 때문에 오히려 절차상 걸리는 것 없이 잘 진행된 것이 아니었을까? (물론 일반 카드결제를 시도하면 당연히 안 될 것이다.)

이 상황을 더 이상은 어떻게 설명을 못하겠다. =_=;;


결론을 내리자면, 국민 대다수가 쓰는 윈도우 운영체제에서는 있는 대로 권력을 행사해서 플러그인 설치를 강요하고 웹 브라우저 선택권을 박탈할 뿐만 아니라 간편결제마저 무력화시키는 우체국 쇼핑몰이, 의외로 윈도우가 아닌 다른 운영체제에서 기대치 못한 편의성을 보여 주었다는 것?

(이게 뭐냐고 ㅜㅜ)


우체국 쇼핑몰은 자사의 매출을 올리고 싶으면 제발 구색만 갖추지 말고, 간편결제는 진짜로 본연의 기능대로 잘 작동할 수 있도록 결제 시스템을 치밀하게 수정하기를 바란다.

반응형
블로그 이미지

Bryan_

,
반응형

OS: Ubuntu 16.04 (amd64)

Printer: HP Color LaserJet CP2025dn



<결론: 해결방법>


우분투 CUPS에서 목록에 보이는 기존 프린터를 삭제하고 같은 프린터를 새로 검색해서 설치한다. (...)



우분투 PC에서 연구실에 있는 네트워크 프린터에 30쪽이 넘는 pdf 문서를 인쇄하던 중, 앞부분 일부만 인쇄가 되고 프린터에서는 페이퍼잼도 없고 아무 오류 메세지도 없이 더이상 진행이 되지 않았다. 우분투에서 프린터 상태 메세지를 보니까 Filter failed 라는 메세지가 떠 있었다.



크롬 브라우저에서 pdf 파일을 직접 인쇄해 봐도 마찬가지였고, 우분투 기본 PDF 뷰어를 통해서 시도해 봐도 똑같았다.



인터넷에 찾아 보니 HP 프린터를 쓰는 사람들에게서 똑같은 문제가 예전부터 있어 왔고, 원인은 뭔지 모르는 경우가 많았다 [1, 2]. 버그 때문이라는 경우도 있고 [3], hp-plugin이 설치되지 않아서 그런 경우도 있는 듯 했다 [4].


일단은 대다수가 추천하는 의견대로 Printers (CUPS)에서 목록에 있는 기존의 프린터를 지우고 새로 설치했더니 오류 메세지가 사라지고 인쇄가 잘 되었다. CUPS는 유니티 런처에서 printers를 입력해서 실행한다.


추가로, 혹시 나중에 hp-plugin 일부가 없어서 똑같은 문제가 생길 가능성도 있으므로, hp-plugin 명령어로 플러그인도 (뭔지는 잘 모르겠지만) 설치해 두었다. hp-plugin은 그냥 터미널 화면에 명령어를 치고, GUI 대화창이 뜨면 recommened 옵션을 선택하고 Next를 눌러 주면 설치가 완료된다.




나중에 또 문제가 생긴다면 그 때 다시 문제를 해결한 다음에 본 문서를 수정해야겠다.



<참고자료>

[1] https://ubuntuforums.org/showthread.php?t=2137098

[2] http://askubuntu.com/questions/378873/cant-print-any-more-stopped-filter-failed

[3] https://bbs.archlinux.org/viewtopic.php?id=148850

[4] http://unix.stackexchange.com/questions/77139/filter-failed-from-hplip


반응형
블로그 이미지

Bryan_

,
반응형

Host OS: Ubuntu 16.04 (amd64)

Guest OS: Windows 10 Enterprise (64-bit)


KVM에서 윈도우10 가상 머신을 하나 만들어서 쓰고 있었는데, 최근에 아침에 확인할 때마다 계속 재부팅이 되어 있는 것이었다. 윈도우 업데이트 중에서 중요한 것들을 자동으로 설치하고 나면 보통 자동으로 재부팅이 되어 있긴 하지만, 최근에는 매일 아침마다 재부팅이 되어 있길래 의아했다.


업데이트 기록을 보니, 다른 업데이트는 다 되는데 버전 1607 (레드스톤)만 업데이트가 안되고 있었다. 직접 virt-viewer 화면을 통해서 수동으로 1607 업데이트를 진행하는 과정을 지켜보니, 업데이트 설치는 되는데 이후 재부팅할 때 블루스크린이 뜨면서 멈췄다가, 그 뒤에 다시 이전 버전으로 롤백해서 재부팅이 되었다.


윈도우10 업데이트 버전 1607이 다른 업데이트와는 달리 거의 서비스팩 수준으로 많은 것이 바뀌는 버전이라서 업데이트 과정에서 VM 설정과 충돌이 났을 지도 모르겠다.


무엇이 원인인지는 찾지 못했지만, 인터넷에 해결 방법은 있었는데 그게 VM의 CPU 쓰레드 개수를 1개로 설정해 놓고 업데이트를 진행하는 것이었다.

그래서 나도 가상 CPU 1개로 설정하고 업데이트를 하니 정말 문제없이 업데이트가 잘 되었다. =_=...


덕분에 매일같이 재부팅되어 있는 문제는 해결했으니 뭐...



<참고자료>

[1] Windows 10 VM crashes on reboot after installing 1607 update, 

https://forums.lime-technology.com/topic/50477-windows-10-vm-crashes-on-reboot-after-installing-1607-update/




반응형
블로그 이미지

Bryan_

,
반응형

TED 강연 링크: http://tv.naver.com/v/960111



이 강연에서는 "마음 챙김"이라고 부르는 훈련에 대해서 간단하게 설명하고 있다. 중독에 빠져드는 (예를 들어, 흡연이나 달콤한 음식을 끊임없이 찾는) 인간의 행동이 작동하는 과정을 계기, 행동, 보상의 과정을 거쳐서 뇌가 반복적으로 학습하는 것으로 설명한다.


이것은 전산학의 인공지능(기계학습) 분야에서 요즘 많이 주목받고 있"강화학습(reinforcement learning)"의 개념과 유사하다. 딱 들어맞지는 않지만...


나쁜 습관은 이를 촉발(trigger)시키는 초기 자극에 대한 행동의 결과를 "좋은 것(달콤한 느낌, 스트레스가 풀리는 기분 등)"으로 반복 학습하면서 뇌 속에서 그 중요도가 점점 커지면서 생겨난다.

초기 자극이 "스트레스를 받을 때, 기분이 좋지 않을 때"와 같은 조건이 되고, 그 때 당사자는 주어진 문제 상황을 해결하는 것과 상관없는 행동(흡연, 단 것 먹기)을 했는데, 그 때의 경험이 짜릿하고 기분이 좋다는 결과로 나타나면서 이를 보상으로 생각하고 뇌 속의 저장소에 저장하는 것이다.


강화학습의 경우, 현재 환경에 대한 상태를 입력값으로 제공받는 컴퓨터가, 그 환경에서 수행 가능한 행동들 중 하나를 선택해서 수행하고, 그 결과로 나타나는 새로운 상태에 대해서 보상을 학습한다. 이 과정을 반복해서, 긍정적인 보상이 최대화되는 행동을 알아내게 된다. 즉, 컴퓨터가 처음에는 취할 수 있는 행동 중 하나를 랜덤으로 선택하지만, 여러 가지 다른 행동들 중에서 보상이 높은 행동에 가중치를 부여함으로써 나중에 동일한(유사한) 상태가 다시 주어지면 빠르게 특정 행동을 취하도록 적응한다.


예를 들면, 스마트 전등이 있고 주어지는 입력값이 시간, 근처에 있는 사용자 이름만 주어지는 아주 단순한 환경을 상상해 보자. 저녁 7시에 사용자 A가 그 전등 근처에 오자, 스마트 전등은 랜덤하게 아무 색깔이나 골라서 불을 켜 주었고, 전등의 색깔에 대해서 사용자가 임의의 점수를 준다고 생각해 보자. 몇몇 색깔의 불에 대해서 높은 점수를 주지 않던 사용자 A가 어느 날 노란색 불을 보고 가장 높은 점수를 주었다. 그리고 며칠 동안 노란색 불이 켜질 때마다 가장 높은 점수를 주게 되면, 스마트 전등은 다음부터는 자동으로 저녁 7시에 사용자 A가 근처에 오면 노란색 불을 켜 주게 된다.


만약 사용자가 갑자기 노란색 불이 싫어서 더이상 노란색 불이 켜지지 않게 하고 싶으면 어떻게 해야 할까? 한동안은 지금까지 학습된 데이터 때문에 자동으로 노란색 불이 켜지겠지만, 사용자가 지속적으로 노란색 불이 켜질 때마다 가장 낮은 점수를 주게 되면, 어느 순간 노란색 불에 대한 보상이 다른 색깔들과 별 차이가 없게 되는 지점으로 돌아오게 된다. 그 지점에서 스마트 전등이 더이상 보상의 메리트가 없는 노란색보다 오히려 미세하게나마 보상이 더 큰 다른 색깔(또는 맨 처음처럼 또 랜덤으로 선택)의 불을 켜주게 될 것이고, 이 때 사용자가 좋아하는 다른 색깔에 대해서 높은 점수를 주기 시작하면, 그 때부터 스마트 전등은 더이상 노란색 불을 켜지 않고 다른 색깔의 불을 켜 주게 된다.

한 술 더 떠서, 노란색 불이 켜질 때마다 최하 점수를 주는 사용자가 그 직후에 직접 전등의 색깔을 파란색으로 바꾼 다음, 파란색 불이 켜진 상태에 대해서 최고 점수를 부여하게 되면 더 빠른 속도로 노란색 불을 켜서는 안된다는 결론에 이를 수 있다. 정확히 말하면, 노란색보다 파란색에 대한 보상이 더 커지므로 파란색 불을 켜는 행동을 빨리 하게 된다.


결국 TED 강연에서 언급되는 "마음 챙김"의 핵심도 이와 비슷한 것 같다. 나쁜 습관을 거의 기계적으로 행동에 옮기도록 만드는 과정에 대해서는 부정적인 보상을 주고, 나쁜 습관을 행동에 옮기지 않는 것(나쁜 습관을 실행하지 않는 의사결정을 내리는 행동)에 대해서는 긍정적인 보상을 주면 된다. (참 쉽죠? ㅋㅋ.. ㅠㅠ)


물론 그게 말처럼 쉽지 않다. 그래서 제안되는 해결책이 나쁜 습관이 발현되는 과정과 나쁜 습관 그 자체를 호기심을 갖고 따져 보라는 것이다. 저드슨 브루어는 왜 내가 지금의 나쁜 습관을 행동에 옮기고 있는지, 그 과정을 왕성한 호기심을 갖고 탐구하라고 조언한다.


사실 전두엽은 나쁜 습관을 행동에 옮기는 것이 나쁘다는 사실을 이성적으로 알고 있기 때문에, 그 전두엽의 활동을 꺼뜨리지 말고 호기심, 탐구정신과 같은 연료를 줘서 계속 생각해 보는 것으로 이해할 수 있겠다. 그러한 나쁜 습관을 지켜보는 즐거운(?) 탐구를 통해서 나쁜 습관이 초래하는 나쁜 결과와 나쁜 습관을 하지 않음으로써 얻는 기쁨/성취감에 대해서 잘 기억해 두자는 것이 핵심이다. 그렇게 탐구하고 잘 기억해 두는 과정을 반복하면 그것이 나쁜 습관과는 반대 방향으로 강화학습을 수행하는 과정이 된다.


이게 말처럼 쉬운지 의심하는 사람들이 많을 것이고, 나도 그 의심을 완전히 떨쳐내지는 못하고 있다. 하지만 확실한 것은, 나쁜 습관을 행동에 옮기는 것이 나쁘니까 스스로를 자꾸 더 자책하여 몰아붙이면서 스트레스를 받으면, 오히려 나쁜 습관을 내려놓는 것이 더 힘들어진다는 것이다. 그 이유는 하필이면 나쁜 습관을 행동에 옮기는 초기 자극의 대부분이 "스트레스를 받을 때"이기 때문이다. 나쁜 습관을 행동에 옮기고 나서 주어지는 뇌 속 호르몬(도파민)의 즐거움이 끝나고 나서 스스로를 몰아붙이고 자책하면 뇌는 또다시 스트레스를 받게 되고, 그 스트레스는 알다시피 나쁜 습관에 대한 초기 자극이 되므로 다시 나쁜 습관을 갈구하게 된다.



그러면 내 상황에 적용해 보자. (부끄럽지만 ㅠㅠ)


중요하면서 어려운 일을 앞두고서 그 일을 처리하는 것이 괴로워서 스트레스를 받을 때, 내가 자꾸만 SNS에 들어가 보거나 무의식중에 인터넷 뉴스를 켜서 재미있고 자극적인 내용의 소식을 찾는 경우가 많다. 뉴스 기사나 페이스북 포스팅 몇 개 읽어보는 것이 그리 많은 시간을 차지하지는 않는다. 그리고 가끔 신기하거나 충격적인 소식을 새롭게 접하면서 어딘지 모를 즐거움까지 느낀다. 일이 어려워서 손에 잘 안 잡힐 때마다 SNS, 뉴스기사를 잠깐씩 찾아보는 행동이 뇌에 일시적으로 도파민을 분비시키고 잠깐 즐겁게 해 주는 동시에 어려운 일처리에 대한 스트레스를 잊게 만든다.

바로 "시험기간에는 시험공부를 제외한 모든 것이 재미있다"는 말과 비슷하다.


결국 일은 일대로 진행이 느리게 되고, 마감 시한이 임박해서까지도 나는 오히려 더 스트레스를 받으면서 더 강한 자극으로 스트레스를 달래고자 방금 전에 이미 다 찾아봤던 SNS와 포털 사이트를 또다시 뒤지고 다니면서 뭔가 새로운 자극적인 소식을 갈구한다. 그러다가 가끔 나무위키와 같은 사이트로 흘러들어가서는 지금 당장 일처리에 필요하지 않은 광범위한 상식들을 읽느라 많은 시간을 소비하기까지 한다.


나는 왜 자꾸 일을 미루면서, 스트레스 유발의 주 원인이 되는 일을 빨리 해결하는 대신 그와 상관없는 지식들을 찾아서 머릿속에 넣으려고 하는 것일까?

대학원의 특성상 해당 일처리는 반드시 누군가의 리뷰를 거치는데, 내 결과물을 리뷰하는 대상이 누가 됐든지 상관없이 나는 모두에게 잘 보이고 싶은 마음이 있음을 알 수 있었다. 남들로부터 인정받고 싶고, 특히 그 일이 무엇이든 상관 없이 일을 못한다는 소리는 정말 너무 듣기 싫다. 그런데 내 입장에서 쉽게 해결이 안되는 꽤 복잡하고 어려운 일이 주어지면, 이것을 완벽하게 처리하지 못함으로써 얻게 되는 리뷰어의 부정적인 평가가 싫은 것이다.


사실은 나한테 어려운 일은 같이 그 일을 진행시켜야 하는 동료들(지도교수, 선배, 후배, 옆 연구실, 정부기관 등 모두 포함) 입장에서도 똑같이 어렵고, 그들도 답을 정확히 모르기도 한다. 따라서 내가 미지의 숲을 헤쳐 나가서 완벽하지 않게나마 얻어낸 중간 결과를 바탕으로 다음 단계를 같이 고민하는 과정이 연구다. 그런데 나는 나 혼자서 완벽하게, 물 흐르듯이, 빈틈없이 일을 처리해서 그들로부터 잘 했다는 평가를 받고 싶은 것이 아닐까?


지금 나는 그런 단기적이고 피상적인 주변의 평가로부터 얻는 즐거움보다 훨씬 더 근본적인 즐거움을 추구하고 있다는 사실을 다시 생각해 내는 것이 중요한 것 같다. 내 앞에 주어진 이 도전적인 일을 처리해서 얻는 결과물이 얼마나 매력적이고, 이를 통해 이 세상에서 이전까지 안되던 일을 되게 만드는 것이 얼마나 즐거운 일인지를 생각해 보는 것이 중요하다.

결국 가장 근본적인 것, 지금 내가 하고 있는 연구가 내 가치관으로 봤을 때 정말 즐거운 일이라는 사실을 지속적으로 되새겨야(remind) 한다. 그 일을 성취해 나가는 과정이 마치 아름다운 정상을 향해서 등산을 하는 것처럼 몸이 좀 힘들지만 즐거운 과정임을 인지해야 한다.

또한 그 일처리 과정에서의 세세한 부분에서 내가 실수를 하거나 남들보다 더디게 진행할 수는 있겠지만, 결국에는 연습하고 익숙해져서 그리 멀지않은 미래에는 내가 원하는 긍정적인 평가를 얻을 수 있게 될 것이다. 지금 당장 모르는 것 때문에 부끄러워하는 것이 아니고, 성장하는 과정이라고 생각할 필요가 있겠다.


그렇다면, 내가 지금 하는 연구는 내 가치관 측면에서 정말로 보람차고 매력적인가? 이것은 맞는 것 같다. 내가 이런 보람찬 일을 한다는 사실을 왜 망각하는 것일까? 왜냐하면 박사과정 졸업을 해야 하는데 자꾸 원치않게 연구기간이 연장되면서, 그 즐거운 일을 계속하고 있음에도 불구하고 내가 너무 못한다고 자책하기 때문이다. 사실 이런 자책을 할 필요가 없다는 점도 명심해야 하겠다. 좀 더디게 성장할 수도 있지, 방향이 틀린 것은 아니기 때문이다. 그리고 지금껏 쌓아 온 지식과 실력이 그리 못 쓸 정도로 엉망이지도 않다. 단지 원하는 때에 졸업요건에 해당하는 논문 실적이 나오지 못한 점 하나만 아쉬운 것이다.


지금 내가 하는 연구와 이 연구를 완성하는 과정에서 얻는 기쁨, C/C++ 코딩 능력을 점차 확장시켜 가는 데서 얻는 성취감, 네트워크 시뮬레이터에서 점차 제 모습을 찾아가는 나만의 모듈들의 유연한 작동 과정을 보는 기쁨을 생각하며, 꾸준하게 즐겁게 연구를 이어 나가고 싶다.


이 글을 쓰기 직전에 나는 분명히 나의 연구의 큰 그림을 실현하기 위한 네트워크 시뮬레이터 코드에서 3일 넘게 나를 괴롭히던 버그를 고쳤다. 그러니까 이제 자고 일어나서 또 즐겁게 다음 모듈을 만들어 봐야겠다. :)



반응형
블로그 이미지

Bryan_

,