Linux 시스템에서 vi 등으로 특정파일을 편집시도시 다음과 같은 에러메시지가 나오면

"Write error in swap file"

위 메시지의 의미는 Swap file을 쓸 수 없다는 말인데, 이러한 문제는 하드디스크 내에 여분의 공간이 없기 때문에

발생한다. 따라서 이 문제를 해결하라면 하드 디스크에서 불필요한 자료들을 삭제해야 해결될것이다.


기본적으로 localhost 에서만 접속이 허용되는 DB 를 외부(PC 및 타 서버) 환경에서 접속하려고 할 때

기존의 db 유저의 host를 변경할 것이 아니라 아래의 쿼리문을 이용해 유저를 추가해주면 된다.

(host 부분의 %는 모든 호스트에서 접속 허용이며 이부분을 IP 주소로 입력하면 해당 IP 에서만 접속이 가능함.)

 

[추가]

1. insert into user (host,user,password) values ('%','user_name',password('user_password'));


[mysql 5.5 이상에서는 아래 쿼리를 실행할 것!!!]

insert into user (Host, User, Password, ssl_cipher, x509_issuer, x509_subject, authentication_string) values('%','user_name', password('user_password'),'','','','');


2. insert into db (host,db,user) values ('%','db_name','user_name');

3. flush privileges;
4. grant all privileges on user_name.* to user_name@'%';

 

(Root 계정의 경우 2번은 생략하고 1번 쿼리 이후 4번 쿼리 중 user_name.* 대신 *.* 로 처리할 것!)

 

5. flush privileges;

 

위 방법대로 했는데도 외부 접속이 안된다면 /etc/my.cnf 파일의 항목 중 bind-address = 127.0.0.1 이 있다면

 

이를 주석처리 한다. (bind-address = 127.0.0.1 는  로컬호스트에서만 접속을 허용한다는 의미임.)

 

bind-address = 127.0.0.1 를 주석처리해도 안된다면 방화벽에서의 mysql 포트 (기본:3306)이 차단되어있을 가능성이 있으므로

 

확인 해 볼것! 

 

[삭제]

아래는 위의 방법대로 외부 접속 호스트 추가 후 삭제하는 방법이다.

(user_name 과 host 부분을 and 조건으로 모두 만족해야 처리되니 주의할 것!!  // % 대신 ip를 입력해도 무방)

 

1. delete from user where user='user_name' and host='%';

(root 계정의 경우 1번만 실행하면 됨)
2. delete from db where user='user_name' and host='%';

flush privileges;



php 컴파일시 아래와 같은 에러 메시지가 나오면

 configure: error: libjpeg.(a|so) not found.

configure: error: libpng.(a|so) not found.


- configure 중 해당 라이브러리가 없어 나는 에러

- 아래의 라이브러리 설치


yum install libjpeg-devel

yum install libpng-devel


해당 라이브러리 설치 후에도 에러가 발생하면 아래와 같이 설정

64bit 운영체제에서 해결이 됨.


ln -s /usr/lib64/libjpeg.so /usr/lib

ln -s /usr/lib64/libpng.so /usr/lib


[출처] http://wnstjqdl.tistory.com/entry/configure-error-libjpegaso-not-found-configure-error-libpngaso-not-found

 

shutdown 명령어를 이용하면 된다.

시작 -> 실행 하고,

shutdown /s /f /t 3600

라고 타이핑 해주면 된다.

/s 는 종료한다는 의미고, 대신 /r 이나 /l 을 붙이면 재부팅 하거나 로그오프 한다. 

/t 뒤에 붙는 3600 은 한시간 예약을 말한다. 적당히 알아서 조절하면 되겟다. 1초단위이며, 최대 예약 시간은 10년이다. (315360000!!)

/f 는 만약 강제 종료가 필요할 대 사용한다. 대화상자가 나와서 종료가 되지 않는 경우 등...

조금 더 많은 옵션을 보고 싶으면 커맨드라인에서 shutdown이라고만 쳐보면 자세한 명령어가 나오니 참조.

만약에 다른 볼일이 생각나서 예약해 놓은 자동꺼짐을 취소하고 싶을 경우에는

shutdown /a

라고 쳐주면 중단한다.

[출처] http://egloos.zum.com/talkable/v/1674594 

  

 

 

페이지 리디렉트와 검색엔진 최적화
301 redirect는 영구적으로 옮겼을때
302 redirect는 일시적으로 옮겼을때 사용
검색엔진 최적화에는 301 redirect 추천


[301 permanent redirect]


사이트를 새로운 도메인으로 옮겼다던가 페이지의 주소가 바뀌었을때 사용자들을 자동으로 바뀐 주소로 옮겨가게 만드는데는 두가지 방법이 있습니다.
301 permanent redirect와 302 temporary redirect 입니다.
301과 302는 사용자가 브라우저를 통해 웹서버에 요청했을때 돌려받는 웹서버의 상태코드입니다.
301은 요청한 정보가 새로운 주소로 영구적으로 옮겨갔다는것을 말해주며 302는 일시적으로 옮겨갔다는것을 말해줍니다.
표면상으로는 둘다 자동으로 사용자를 옮겨가게 만드니 사람의 육안으로는 구별할수 없으나 검색엔진 크롤러는 그 차이를 알수 있고, 이 두가지가 검색엔진 최적화에 미치는 영향은 꽤 큽니다.



이것은 말그대로 요청한 정보(사이트나 페이지)가 영구적으로 옮겼다는것을 말해줍니다.

 

예를 들어 aaa.com을 소유했던 사람이 bbb.com으로 사이트 주소를 옮겼을때 301 redirect를 해준다면 크롤러가 aaa.com에 접속했을때 aaa.com에서 인덱스한 내용의 주소가 bbb.com으로 바뀌었다는것을 감지하고 인덱스된 aaa.com의 주소를 자동으로 bbb.com으로 변경시켜 줍니다.

이럴경우 ‘aaa’라는 키워드로 aaa.com이 검색결과에 나오던것이 bbb.com으로 나오게 되는 것입니다.

이렇게 되면 사이트 관리자는 손쉽게 검색엔진에 변경된 사항을 적용할수 있게되고 검색엔진을 통해 유입되는 트래픽을 잃지 않게 됩니다.

그외에 www.aaa.com을 ‘www’가 빠진 aaa.com으로 지정하고 싶다던지 www.aaa.com/product.html?a=samsung&b=galaxy&c=tab 같은 url을 www.aaa.com/samsung/galaxy/tab 같이 읽기 쉬운 형식으로 바꾸고 싶을때 유용하게 쓰입니다.


[302 temporary redirect]


302 redirect는 현재 페이지나 사이트를 일시적으로만 옮겼다는것을 말해줍니다.

 

대부분 javascript를 이용한 redirect, 메타태그(< meta http-equiv="refresh" content="0;url=http://새로운주소.com" />)를 이용한 redirect 또는 각각의 프로그래밍 언어를 사용한 단순 redirect가 이에 포함됩니다.

aaa.com 소유자가 bbb.com으로 사이트를 옮겼는데 잘모르고 302 redirect를 해주게 되는경우 사용자는 자동으로 옮겨가게 되지만, 크롤러는 사이트가 옮겨갔다는것을 감지하더라도 일시적으로만 옮겨간것으로 간주하기 때문에 검색결과에 아무런 변화를 주지 않게 됩니다.

그래서 특정 키워드로 검색을 했을때 aaa.com이 나오던것이 bbb.com으로 업데이트되지 않게 됩니다.

간혹 이것을 악용하여 특정 키워드로 최적화된 페이지를 방문한 사용자를 자동으로 페이지와 전혀 상관없는 광고성 페이지로 옮겨가게 만드는 경우도 있습니다.

구글은 이를 doorway page로 여겨 페널티를 부과하기때문에 302 redirect를 사용할때에는 잘 생각해보시고 사용하시기 바랍니다.

대부분의 경우 302 보다 301 redirect를 사용하시는것을 추천합니다.


301 redirect 사용방법
301 redirect 사용방법에는 여러가지가 있습니다.
사용하는 프로그래밍 언어에 따라 약간씩 틀리고 .htaccess 파일 수정을 통해 mod_rewrite을 사용할수 있습니다.


0. apache 에 직접 등록시

<virtualhost> 와 </virtualhost> 사이에 아래의 룰을 추가

Redirect 301 / http://연결될도메인.com



1. PHP redirect

<?php
header( "HTTP/1.1 301 Moved Permanently" );
header( "Location: http://www.new-url.com" );
?>

2. JSP(Java) redirect

< %
response.setStatus(301);
response.setHeader( "Location", "http://www.new-url.com/" );
response.setHeader( "Connection", "close" );
%>

3. ASP.NET redirect

<script runat="server">
private void Page_Load(object sender, System.EventArgs e)
{
    Response.Status = "301 Moved Permanently";
    Response.AddHeader("Location","http://www.new-url.com");
}
</script>
4. ASP redirect
< %@ Language=VBScript %>
<%
Response.Status="301 Moved Permanently"
Response.AddHeader "Location","http://www.new-url.com/"
%>

5. Ruby on Rails redirect

def old_action
headers["Status"] = "301 Moved Permanently"
redirect_to "http://www.new-url.com/"
end

6. CGI Perl redirect

$q = new CGI;
print $q->redirect("http://www.new-url.com/");

7. .htaccess mod_rewrite

RewriteEngine on
RewriteRule (.*) http://www.new-url.com/$1 [R=301,L]

.htaccess의 mod_rewrite 같은 경우 사용법이 훨씬 다양하며 자세한 내용은 http://httpd.apache.org/docs/current/mod/mod_rewrite.html를 참조하시기 바랍니다.