기본적으로 웹서버용으로 사용할때는 Jit이 기본적으로 활성화됩니다.
server.ini에 jit_profile_interp_requests 설정이 기본값이 11입니다.
이말은 브라우저에서 특정페이지에 대한 request를 10번까지할때는 컴파일러가 중간코드로 컴파일을 하게 되므로, 속도가 느려지지만..11번째부터는 machine native code로 실행되므로 속도가 무지 빨라집니다.
이렇게 바로 중간코드 안거치고 native code로 실행하지 않는 이유는 페이스북 엔지니어들의 말을 따르면, 최적화된 native code로 컴파일하기위한 정보수집때문이라네요.
가령 어떤 function에 파라미터로 넘어오는 값들이 int형인지? string형인지?등을 알아내기위하여
테스트하고 데이터값을 통계적으로 추측해내느라 (10번째까지의 request) 필수적이라고 합니다.
또는, redis / memcache / apc같은 캐싱서버가 중간에 끼어있을경우, 1번째 실행시에 캐시서버에 저장하고, 2번째이후부터 캐시서버에서 데이터가져오는 패턴으로 코드가 짜여있을경우, 대부분의 코드실행은 캐시서버에서 가져오는 루틴이므로 ..이러한것들도 컴파일시에 참고하려고 등등...
이과정을 그래서 warmming up 이라고 하고, 11번째부터는 native code로 실행하므로 cool up이라고 합니다.
그런데 서버운영해보면 사실 그거 한다고 더 최적화되는 느낌은 없구요.
그냥 jit_profile_interp_request = 1 로 놓고 하는게 훨 낫습니다. 1번째 request만 warm up하고, 그 다음부턴 바로 native code로 실행되니까요~~~
hhvm.jit_profile_interp_requests = 11
hhvm.jit_a_size = 62914560
hhvm.jit_a_cold_size = 25165824
hhvm.jit_a_frozen_size = 41943040
hhvm.jit_a_hot_size = 0
hhvm.jit_a_prof_size = 67108864
hhvm.jit_a_max_usage = 62914560
게시글 목록
| 번호 | 제목 |
|---|---|
| 20097 | |
| 20095 | |
| 20093 | |
| 20092 | |
| 20091 | |
| 20089 | |
| 20086 | |
| 20085 | |
| 20084 | |
| 20083 | |
| 20082 | |
| 28358 | |
| 20081 | |
| 20079 | |
| 20078 | |
| 20077 | |
| 20076 | |
| 20075 | |
| 20074 | |
| 20073 |
PHP
php환경 변수 출력 입니다.
|
| 20072 |
PHP
PHP팁 (보안 등) 입니다.
|
| 20071 |
PHP
문자열 자르는 함수 입니다.
|
| 20070 | |
| 20069 | |
| 8148 | |
| 20057 |
정규표현식
파싱 예제입니다.
11
|
| 8141 | |
| 24669 | |
| 20056 | |
| 8138 | |
| 28353 | |
| 20055 | |
| 20054 | |
| 20053 | |
| 20052 | |
| 20051 | |
| 20050 |
JavaScript
지난 시간 경과시간 페이스북 sns 처럼 보여주기 javascript 버전
|
| 20047 | |
| 20046 |
PHP
php환경맞춤 부분 입니다.
|
| 20045 | |
| 20044 | |
| 8111 | |
| 20043 | |
| 20042 | |
| 20040 | |
| 20039 |
JavaScript
구글 맞춤검색 설정 방법, google custom search
|
| 20037 | |
| 20036 | |
| 20035 | |
| 20027 |
MySQL
1000만건 게시판에 도전합니다. 두번째
7
|
| 8107 | |
| 31022 | |
| 20026 |
MySQL
Join 을 이용한 delete
|
| 20025 | |
| 20024 | |
| 20023 |
PHP
미리 정의된 변수들 입니다.
|
| 28350 | |
| 20022 | |
| 20018 |
MySQL
1000만건 게시판에 도전합니다. 첫번째
3
|
| 20017 |
MySQL
select 해서 바로 insert하기
|
| 8099 | |
| 20016 | |
| 20013 | |
| 8090 | |
| 20012 | |
| 20010 | |
| 20009 | |
| 19998 |
PHP
텔레그램 푸쉬 봇
10
|
| 28348 | |
| 28347 | |
| 19997 | |
| 19996 |
OS
파일분할 분할압축 해제
|
| 19995 |
웹서버
리눅스백그라운드실행
|
| 19993 | |
| 8087 | |
| 8065 | |
| 19990 | |
| 8063 | |
| 8056 | |
| 19989 | |
| 19988 | |
| 19987 | |
| 19986 | |
| 19985 | |
| 19984 | |
| 19983 | |
| 19982 |
MySQL
mysql에서 boolean 타입 사용하기
|
| 8054 | |
| 19981 | |
| 19980 | |
| 19979 |
MySQL
mysqladmin 상태 모니터링
|
| 19978 | |
| 19977 | |
| 19976 |
웹서버
리눅스 프로세스 검사, 조회
|
| 19975 |
웹서버
리눅스에서 네트워크 상태 보기
|
| 19974 |
웹서버
리눅스 80 포트 방화벽 열기
|
| 19973 | |
| 19972 |
MySQL
Mysql Table 일괄 삭제 방법.
|
| 19971 | |
| 19970 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기