집에 있는 라즈베리파이에 홈페이지를 구축하거나,
웹이나 핸드폰으로 접속해서 라즈베리파이를 원격제어 원하시는 분들을 위해 간단하게 강좌를 올려봅니다.

 

대부분 집의 인터넷망은  유동아이피 입니다. 공유기를 꺼다 키거나 하면 아이피가 변경될수 있습니다.

이 아이피를 고정하기위해서는 별도의 비용을 지불하면 고정아이피를 발급 받을수 있습니다.

다른 방법도 있습니다. 공유기 설정과 DDNS을 이용해서 사용하는 방법도 있습니다.

 

일단 아래와 같이 공유기에 포트 포워딩을 해줍니다.

필자는 iptime을 기준으로 진행하겠습니다.

 

 

 

 

아래와 같은 방법으로 192.168.0.30은 라즈베리 파이의 고정 아이피이고 외부에서 80 일명 웹포트로 접속시 내부포트 80으로 연결합니다.

부가적으로 ssh 은 22 포트를 사용합니다. ssh 포트도 추가하면 putty 등의 터미널로 원결 접속할수도 있습니다.

 

아이피를 고정하는 법은 아래의 포스트를 참고하세요.

2015/05/03 라즈베리파이 2 무선랜 아이피 고정하기 (2)

 

 

외부아이피 확인하기,

아래와 같이 확인하는 법도 있고,

http://ipconfig.co.kr/

와 같은 사이트로 가시도 됩니다.

 

 

DDNS을 이용하여  dns및 설정법에 대해서 알려드리겠습니다. 아래와 용어 정리 참고.

DDNS(다이나믹DNS) :IP가 수시로 변경되는 유동IP 환경에서도, 자신의 도메인을 연결하여 서버를 쉽게 연결할 수 있습니다.


ddns 여러개의 사이트에서 진행하고 있습니다. 

아래와 사이트 강추합니다. 무료이고, 사용하기 편합니다.


https://dnszi.com

 

일단 회원가입하시면,

dnszi을 dns서버정보를 아래와 같이 알수 있습니다.

 

 

 

 

위의 DNS 정보를 자신이 도메인을 등록한 업체에서 네임서버주소를 변경합니다.

DNS정보 변경은 보통 12-24시간 정도 변경되는 시간이 걸립니다.

참고로 필자를 hosting.kr을 사용하고 있고, 보통 .com은  일년에 만원정도 합니다.

 

 

 

인제 https://dnszi.com/domain_add.html 

으로 가셔서 도메인을 추가해 줍니다.

 

 

 

호스트 레코드 관리에 아래와 같이 설정해 줍니다.

설정한때 꼭 DDNS설정을 O로 선택해주세요.

 

 

 

고급관리화면으로 가시면 ddns에 대한 설정을 할수 있습니다.

인증키를 생성받고 아래와 같이 /etc/crontab에 wget을 5분에 한번씩 실행해서 현재 외부 아이피을 dnsi 네임서버로 알려주게 됩니다.

주의하실 점은  wget의 위치가 서버환경에 따라 달라질수 있습니다.

 

 

 

 

 

 

이모든 설정이 정상적으로 되고, 웹서버 설정에 이상이 없다면.

필자처럼 도메인으로 라즈베리파이 웹페이지에 접속하실수 있습니다.

 

웹서버 구축에 대해서는 아래의 포스트 참고하세요.

라즈베리파이 2에서 APM(Apache,PHP,Mysql) 구축및 환경설정

 

http://fishdefend.com/

 

 

 

누군가에 도움이 되는 글이었으면 좋겠습니다.

여러분이 접속할때 마다, 제 라즈베리파이 릴레이 모듈은 리셋되면서 드르릉 소리가 날것 같네요 ^--^

버튼 on,off 할때마다 딸깔 딸깔 소리가 납니다. ^^  아직 인증 안 걸어 놓았습니다.

 

궁금하신 점은, 블로그 댓글을 통해서 올려주시면 답변드리겠습니다.

  1. 2558 2018.07.20 15:12 신고

    좋은 정보 감사합니다. 도움이 되었네요. 릴레이도 좋지만 영구적으로 사용할 수 있는 무접점릴레이 SSR을 써보세요.

이번 시간에는 라즈베리파이와 릴레이(relay) 모듈을 이용해서 웹에서 전원 제어하는 법에 대해서 다루겠다.

개발환경은 아파치+PHP+wiringpi 이다.

 

아파치+php+mysql 환경 구축은 아래의 링크을 확인하면 되고,

http://www.ilikesan.com/entry/라즈베리파이-2-에서-APMApachePHPMysql-구축및-환경설정

 

wiringpi  설치는 아래의 정식 홈페이지를 참고하시면 된다.

http://wiringpi.com/download-and-install/

 

아래의 동영상을 보면 실제 작동되는 영상과 전체적인 연결되어 있는 모습을 확인할수 있다.

 

 

프로그램소스는 아래와 같다.

------------------ relay.php --------------------------

<?php
if(@$_GET['mode']) $mode=$_GET['mode'];
else $mode="";
if($mode=="act")
{
 $str_com2="gpio write ".$_GET['gpio']." ".$_GET['value'];
// echo $str_com2;
 $re2=exec($str_com2);
 exit;
}

//디바이스 셋업
$pi_relay =array(
 array('name' =>'전원1' ,
  'gpio' =>'0',
  ),
 array('name' =>'전원2' ,
  'gpio' =>'1',
  ),
 array('name' =>'전원3' ,
  'gpio' =>'2',
  ),
 array('name' =>'전원4' ,
  'gpio' =>'3',
  ) 
);

for($i=0; $i<count($pi_relay); $i++)
{
 $relay=$pi_relay[$i];
 //gpio mode 설정
 $str_com1="gpio mode ".$relay['gpio']." out";
 //gpio 디지털 write
 $str_com2="gpio write ".$relay['gpio']." 0";
 $re1=exec($str_com1);
 $re2=exec($str_com2);
}
?>
<!DOCTYPE html>
<html lang="ko">
<head>
<meta charset="utf-8">
 <title>My Page</title>
 <meta name="viewport" content="width=device-width, initial-scale=1">
 <link rel="stylesheet" href="http://code.jquery.com/mobile/1.1.2/jquery.mobile-1.1.2.min.css" />
 <script src="http://code.jquery.com/jquery-1.7.2.min.js"></script>
 <script src="http://code.jquery.com/mobile/1.1.2/jquery.mobile-1.1.2.min.js"></script>
</head>
<body>
<script>
function relay_chg(gpio,value)
{
 $.get( "?mode=act&gpio="+gpio+"&value="+value, function( data ) {
//   alert( "Data Loaded: " + data );
 });

//$.get( "?", { mode: "act", gpio: value } );
}
</script>
<div data-role="page">

 <div data-role="header">
  <h1> 4-Channel Relay Test </h1>
 </div><!-- /header -->

 <div data-role="content"> 
<?php
for($i=0; $i<count($pi_relay); $i++)
{
 $relay=$pi_relay[$i];
?>
<div class="containing-element">
 <label for="flip-min"><?echo $relay['name']?>:</label>
 <select name="flip-min" id="flip-min" data-role="slider" onchange="relay_chg('<?echo $relay['gpio']?>', this.value);">
  <option value="0" selected="selected">Off</option>
  <option value="1">On</option>
 </select>
</div>
<?php
}
?>
 </div><!-- /content -->

</div><!-- /page -->

</body>
</html>

------------------ relay.php --------------------------

위와 같은 웹프로그램 아래와 같은 웹화면으로 나온다.

jquery + jquery mobile 기반으로 핸드폰과 PC에서 제어하기 편하도록 되어 있다.

 

 

 

 

 

 아래 ↓ 라즈베리파이+ 브레드보드 + 릴레이모듈 연결사진

 

 

 아래 ↓ 브레드보드 회로 구성 간단하다.

 

 

 아래 ↓ 5채널 릴레이 모듈 연결사진

 

 

 

 

 

아래 부터는 전기 배선에 대한 사진들이다. 220V 이므로 감전및 화재에 주의 하시기 바랍니다. 혹시 모를 사고를 위해 전기에 대한 전문적인 지식이 있는 분의 도움을 받으시기를 바란다.

 

  아래 ↓ 전원선중 하나를 짤라서 릴레이 모듈에 연결했다.

 

 

  아래 ↓ 2구 콘센트를 직접만들었다.

 

  아래 ↓ 플러그는 아래와 같이 만들었다.

 

 

이상으로 강좌를 마치겠다.

다음 강좌는 릴레이 모듈 프로그램에 스케쥴을 걸어서 정해진 시간에 전원이 on/off 되도록 하는 프로그램과

집 밖에서도 핸드폰등 웹화면에서 전원(릴레이 모듈)을 제어할 수 있는 방법에 대해서 다루겠다.

  1. 피르 2015.07.01 17:21 신고

    라즈베리파이와 릴레이모듈을 사용할 일이 생겨서 검색하다가 방문하게 되었습니다.
    저희가 주문해서 받은 T자형 확장 모듈..이라고 하나요? 그걸 사용해서 하려고 하니 전류가 안흐르는것같은데, 혹시 이걸 사용하려면 꼭 납땜을 해야만 하나요? 사진이나 동영상을 보니 납땜을 하신것 같던데...
    답변해주시면 정말 감사하겠습니다. 많은 도움 얻고 가는것 같네요.

    • Favicon of http://ilikesan.tistory.com BlogIcon 산좋아해 2015.07.02 11:45 신고

      별도의 납땜은 필요없습니다.
      접속 불량일수도 있고,
      모듈마다 필요한 전압과 전류가 달라서 생기는 문제도 있으니,
      멀티미터로 한번 체크해 보시기 바랍니다.
      도움이 되었으면 좋겠습니다.

  2. BlogIcon 신해철 2015.09.17 13:58 신고

    아 꼭 해보고싶은 작업인데요.
    우선 저 릴레이모듈은 직접 만드신거에요?
    살려고 보니까 없는것 같은데 어디서 구할 수 있는지 도움좀 주세요~

    • Favicon of http://ilikesan.tistory.com BlogIcon 산좋아해 2015.10.28 11:17 신고

      릴레이모듈은 인터넷에 팔아요.
      인터넷에 릴레이모듈 치면 되고요.
      해외쇼핑몰 알리익스프레스에서 싸게 팔아요.
      아마존도 좋구요.

  3. 공대생 2017.03.10 17:39 신고

    라즈베리파이로 릴레이모듈을 통하여 제어를 하려고하는데, 작성자님의 코딩을 이용하였습니다. 그런데 궁금한것이몇가지 생겨 이렇게 글을 남깁니다.
    1. gpio값을 지정해주지 않았는데 on/off가 되나요? 작성자님은 gpio 17,18,22,27을 사용하셨던데 코딩에는 이것을 사용하는 어떠한 글이없던데 어떻게 동작하는건가요?
    2. 인터넷 서버창 까지는 띄웠는데 인터넷 창이 형성되면 따로 실행 코딩은 필요없는것인가요? python기본 예제에서 LED 제어하는 다른 분의 글에선 sudo python relayLED.py처럼 실행을 시키면 작동이 되곤 했었는데 서버 생성하면 다른 동작없이 서버의 리모콘으로 제어가 가능한것인가요?
    현재 저희는 서버창 까지 띄웠으나 서버에 버튼을 조작하여도 특별한 변화가 없습니다. 늦게 댓글을 달았는데 혹시 기억이나신다면 부탁드리겠습니다.

저번 시간에 이어 ds1820 온도센서를 이용해서 온도를 자동 저장하고 그래프로 출력하는 법에 대해서 강좌 하도록 하겠다.

아래의 강좌을 읽으면 프로그램을 이해하는데 도움이 된다.

  1. 2015/05/14 라즈베리파이 2 DS18B20 온도센서 PHP 프로그램, MySQL DB 저장 (2)
  2. 2015/05/13 라즈베리파이 2에서 APM(Apache,PHP,Mysql) 구축및 환경설정
  3. 2015/05/09 아두이노 라즈베리파이 온도센서 방수형 DS18B20 사용법
  4. 2015/05/09 라즈베리파이 아두이노 온도센서 방수형 DS18b20 상품 설명과 구매

crontab에 아래와 같이 일분에 한번 실행되도록 등록한다.

----------- 아래 --------
#temperature  auto save
* *     * * *   root    /usr/bin/php -q /home/pi/daemon_php/temp_save.php

----------- 아래 --------

 

crontab은 /etc/crontab 에 있으니 vi등을 이용해서 추가하면된다.

php는 웹폴더에 두지말고, 다른 폴더를 생성하기 바란다.

필자는 /home/pi/daemon_php/ 에 파일을 생성했다.

 

---------------------------- temp_save.php-------------------------------

<?php
// mysql 접속 계정 정보
$mysql_host = 'localhost';
$mysql_user = 'pi';
$mysql_password = 'XXXX';
$mysql_db = 'pi';

// 접속
$conn = mysql_connect($mysql_host, $mysql_user, $mysql_password);
$dbconn = mysql_select_db($mysql_db, $conn);


// charset 설정, 설정하지 않으면 기본 mysql 설정으로 됨, 대체적으로 euc-kr를 많이 사용
//mysql_query("set names utf8"); 


//리눅스 명령어를 cat을 실행해서 온도센서의 데이터를 읽어 들인다.
$re=exec("cat /sys/bus/w1/drivers/w1_slave_driver/28-*/w1_slave");

//데이터중 온도값의 값을 추출하기위해서 "t="기준으로 배열로 분리한다.
$tem_c=explode("t=",$re);
//온도
$data['temp_c']=round($tem_c[1]/1000,2);
//날짜
$data['temp_ymd']=date("Ymd");
//시간
$data['temp_his']=date("His");



//쿼리, news 라는 테이블이 존재, id, title, content 필드가 존재할 경우
$query = "INSERT INTO `temperature`(`time_ymd`, `time_his`, `temperature`, `regday`) ";
$query .= "VALUES ('".$data['temp_ymd']."','".$data['temp_his']."', '".$data['temp_c']."', now() )";

//테스트를 위해서 쿼리출력
echo $query;

//쿼리 실행
$res = mysql_query($query, $conn);

?>
---------------------------- temp_save.php-------------------------------

 

 

프로그램이 정상적으로 실행되면 아래 처럼 일분에 한번씩 온도가 자동 저장된다.

 

 

저장된 온도를 하이차트를 이용해서 그래프로 출력하는 법을 익혀보겠다.

간단한 통계처리라면 구글차트도 좋지만, 하이차트는 개인 홈페이지는 무료이고 상용홈페이지도 저렴한 가격이고 다양한 그래프을 제공한다.

자바스크립트환경이고 모바일도 잘 지원된다.

아래의 사이트에서 방문해 보시기 바란다.

http://www.highcharts.com/demo

 

설치법은 해당프로그램 다운받고, 압축을 풀어서 웹폴더에 올리기만 하면된다.

 

최근 12시간의 온도 변화를 보여주는 프로그램은 아래와 같다.

 

----------------- temp.php-------------------------

<?php

$mysql_host = 'localhost';
$mysql_user = 'pi';
$mysql_password = 'XXXX';
$mysql_db = 'pi';

// 접속
$conn = mysql_connect($mysql_host, $mysql_user, $mysql_password);
$dbconn = mysql_select_db($mysql_db, $conn);


// charset 설정, 설정하지 않으면 기본 mysql 설정으로 됨, 대체적으로 euc-kr를 많이 사용
//mysql_query("set names utf8");


$sql="
select * from (
SELECT DATE_FORMAT( regday,  '%m-%d %HH' )  mdh , COUNT( * ) cnt, SUM( temperature ) , round(SUM( temperature ) / COUNT( * ),2)  atemper
FROM  `temperature`
GROUP BY DATE_FORMAT( regday,  '%Y%m%d%H' )
order by regday desc
limit 12 
) t_a
order by t_a.mdh
";
//echo $sql;

 

$result = mysql_query($sql) ;


$str_mdh="";
$str_atemper="";
while ($row = mysql_fetch_array($result, MYSQL_ASSOC)) {
// echo($row['mdh']."--------------".$row['atemper']."<br>");
 $str_mdh .="'".$row['mdh']."',";
 $str_atemper .="".$row['atemper'].",";
}
$str_mdh= substr($str_mdh,0,-1);
$str_atemper= substr($str_atemper,0,-1);
//echo $str_atemper;

?><!DOCTYPE HTML>
<html>
 <head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  <title>Temperature Example</title>

  <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.2/jquery.min.js"></script>
  <style type="text/css">
${demo.css}
  </style>
  <script type="text/javascript">
$(function () {
    $('#container').highcharts({
        chart: {
            type: 'line'
        },
        title: {
            text: 'Average Temperature'
        },
        subtitle: {
            text: 'Source: ilikesan.com'
        },
        xAxis: {
            categories: [<?php echo $str_mdh?>]
        },
        yAxis: {
            title: {
                text: 'Temperature (°C)'
            }
        },
        plotOptions: {
            line: {
                dataLabels: {
                    enabled: true
                },
                enableMouseTracking: false
            }
        },
        series: [{
            name: 'Home',
            data: [<?php echo $str_atemper?>]
        }
   /*
   , {
            name: 'London',
            data: [3.9, 4.2, 5.7, 8.5, 11.9, 15.2, 17.0, 16.6, 14.2, 10.3, 6.6, 4.8]
        }
  */
  ]
    });
});
  </script>
 </head>
 <body>
<script src="/highchart/js/highcharts.js"></script>
<script src="/highchart/js/modules/exporting.js"></script>

<div id="container" style="min-width: 310px; height: 400px; margin: 0 auto"></div>

 </body>
</html>

----------------- temp.php-------------------------

 

웹에서 확인하면, 아래와 같이 잘 나온다.

 

 

다음 강좌에서는 릴레이을 이용해서 여러개의 전원을 php 프로그램을 이용해서 컨트롤 하는 법에 대해서 다루어 보겠다.

 

 

 

라즈베리파이에서 php 에러 구문이 막혀있는 아래와 같은 방법으로 출력하면 된다.

 

# php.ini 파일을 vi로 열고

sudo vi /etc/php5/apache2/php.ini

 

# php.ini 파일에서 아래의 설정변수를 Off에서 On으로 변경

display_errors = On

 

# 아파치를 리스타트해서 php.ini 파일을 적용한다.
sudo /etc/init.d/apache2 restart

 

라즈베리파이 2 에서 온도센서를 PHP로 읽어 들이고, Mysql DB에 저장하는 법에 대해서 배우겠다.

이강좌를 이해하기 위해서는 앞의 강좌를 먼저 읽어 봐야한다.

그리고 , 당연히 Apach+ PHP + Mysql 환경 이어야 한다.

그런 본론으로 들어 가겠다.

 

아래는 먼저 읽어야하는 강좌 리스트 이다.

  1. 2015/05/13 라즈베리파이 2에서 APM(Apache,PHP,Mysql) 구축및 환경설정
  2. 2015/05/09 아두이노 라즈베리파이 온도센서 방수형 DS18B20 사용법
  3. 2015/05/09 라즈베리파이 아두이노 온도센서 방수형 DS18b20 상품 설명과 구매

 

일단 온도센서를 읽어들이는 출력하는 프로그램은 다음과 같다.

DB18B20.php

<?php
//리눅스 명령어를 cat을 실행해서 온도센서의 데이터를 읽어 들인다.
$re=exec("cat /sys/bus/w1/drivers/w1_slave_driver/28-*/w1_slave");
//데이터중 온도값의 값을 추출하기위해서 "t="기준으로 배열로 분리한다.
$tem_c=explode("t=",$re);
//현재 시간 과 온도값을 천으로 나누고, 소숫점 둘째자리에서 반올림 해서 출력한다.
echo ( "Time = ".date("Y-m-d H:i:s")." , Temperature =  ".round($tem_c[1]/1000,2)." C ");
?>


 

해당 프로그램을 웹에서 호출하면,

 

 

 

 

이 얼마나 간결하고 아름다운가? 감탄사가  헐~~~ 하고 나온다.

 

C, perl,자바(JSP), 파이썬 너희들 대가리 박고  웹에서는 덤비지 말라는 애기가 절로 나온다.

느들 주석빼고 , 3줄로 웹에 온도 센서값 뿌려줄수 있어?

 

C,자바 개발자가 돌 던지는 소리가 들린다. 웹 전용 랭귀지가 어디서 덤비냐?

이런 애비애미 못 알아 보는 놈 , 웃자고 하는 애기니 열받지 마시기를 ㅎㅎ

 

그럼 디비에 저장하는 법을 배워보겠다.

 

일단 Mysql 에 저장한 테이블을 생성하자.

--------- 테이블 생성 -----------


CREATE TABLE IF NOT EXISTS `temperature` (
  `no` int(10) NOT NULL AUTO_INCREMENT COMMENT '번호',
  `time_ymd` char(8) NOT NULL COMMENT '날짜 ',
  `time_his` char(6) NOT NULL COMMENT '시간',
  `temperature` float NOT NULL COMMENT '온도',
  `regday` datetime NOT NULL COMMENT '저장시간',
  PRIMARY KEY (`no`),
  KEY `time_ymd` (`time_ymd`,`time_his`,`regday`)
) ENGINE=InnoDB  DEFAULT CHARSET=utf8 ;


--------- 테이블 생성 -----------

 

--------------- php 프로그램 ------------

<?php
// mysql 접속 계정 정보
$mysql_host = 'localhost';
$mysql_user = 'pi';
$mysql_password = 'XXXXXX';
$mysql_db = 'pi';
// 접속
$conn = mysql_connect($mysql_host, $mysql_user, $mysql_password);
$dbconn = mysql_select_db($mysql_db, $conn);
 
// charset 설정, 설정하지 않으면 기본 mysql 설정으로 됨, 대체적으로 euc-kr를 많이 사용
//mysql_query("set names utf8");
 
//리눅스 명령어를 cat을 실행해서 온도센서의 데이터를 읽어 들인다.
$re=exec("cat /sys/bus/w1/drivers/w1_slave_driver/28-*/w1_slave");
//데이터중 온도값의 값을 추출하기위해서 "t="기준으로 배열로 분리한다.
$tem_c=explode("t=",$re);
//온도
$data['temp_c']=round($tem_c[1]/1000,2);
//날짜
$data['temp_ymd']=date("Ymd");
//시간
$data['temp_his']=date("His");
 
//insert sql 스트링 만들기 
$query = "INSERT INTO `temperature`(`time_ymd`, `time_his`, `temperature`, `regday`) ";
$query .= "VALUES ('".$data['temp_ymd']."','".$data['temp_his']."', '".$data['temp_c']."', now() )";
//테스트를 위해서 쿼리출력
echo $query;
//쿼리 실행
$res = mysql_query($query, $conn);
?>

웹브라우저로 실행,

 

 

 

 

실제 디비에 저장된 데이타를 phpmyadmin 에서 확인

 

 

 

다음 강좌에는 위의 프로그램을 일정시간 간격으로 자동으로 DB에 저장하고 그래프로 표현하는 법에 대해서 배워보겠다.

 

  1. BlogIcon 주호택 2015.05.24 21:54 신고

    도움 많이 받았습니다!

    • Favicon of http://ilikesan.tistory.com BlogIcon 산좋아해 2015.05.26 10:20 신고

      반갑습니다. 공부하고 있는 내용을 정리하고 있는 중인데,
      주호택님에게 도움이 되었다니 기분 좋습니다.
      즐거운 하루 되세요.

  2. BlogIcon 정응재 2015.06.05 16:46 신고

    정리 대단하시네요.. 정말 도움 많이 받았습니다.. 그런데 저는 온도센서를 라즈베리파이에 직접 연결하지 않고
    릴레이모듈에 연결한 뒤 블루투스 이용해 파이로 값을 받으려고하는데.. 아무리 찾아봐도 안나오네요..
    블루투스모듈 사용하는 방법좀 여쭤봐도될까요??

    • Favicon of http://ilikesan.tistory.com BlogIcon 산좋아해 2015.06.08 17:07 신고

      공부하면서 메모식으로 정리하고 있는데,
      칭찬도 해주시고, 더 정성을 들여야겠네요.
      릴레이모듈을 전원을 제어하는 것인데 어떻게 연결되지는 모르겠네요.
      릴레이모듈이 아니고 아두이노 아닌가요?
      아래의 동영상 강좌 추천합니다.
      https://www.youtube.com/watch?v=0mnp7m-v_30

  3. 김유리 2015.06.15 16:35 신고

    안녕하세요 글 잘읽었습니다! 저도 이와 관련된 프로젝트를 진행하고 있는 학생인데요~ 지그비를 통해 받아들여온 데이터를 db에 저장하려면 어떤 방법을 써야하는지 혹시 아시나요?~ㅎㅎ

    • Favicon of http://ilikesan.tistory.com BlogIcon 산좋아해 2015.06.16 12:03 신고

      지그비를 통해 받아들여온 데이터를 바로 DB에 저장은 안 될것같습니다.
      아두이노, 라즈베리 파이와 통신해서 데이터 값을 넘기고,
      넘어온 데이타를 DB에 저장해야 할것 같습니다.
      아두이노는 자체에 DB 서버 설치가 불가하니 외부에 DB서버에 두어 데이타값을 전송해서 저장하면 되고요.
      라즈베리는 DB서버를 세팅해서 저장하시면 됩니다.
      아래의 url을 참고하세요.
      열심히 공부하셔서 프로젝트 잘 마무리하시기 빌겠습니다.
      https://devworksinprogress.wordpress.com/2011/06/18/project-zigbee-temperature-sensor/
      http://blog.killdoslab.com/220233558357?Redirect=Log&from=postView

  4. 김유리 2015.06.18 19:27 신고

    자세한 답변 정말 감사합니다!!!ㅎㅎ 다행히도 잘 해결되었습니다! 좋은 하루되세요~ㅎㅎ

  5. BlogIcon 김병수 2015.10.29 15:22 신고

    라즈베리파이 초보입니다. 이번에 php를 통해 외부 db와 연동하려합니다.
    라즈베리파이로 읽어온 데이타를 위에 php 파일에 localhost부분을 외부 db서버에 ip주소로 바꿔주면 외부 디비도 갱신할 수 있을까요?

라즈베리파이 에서 APM(Apache,PHP,Mysql) 환경 구축에 대해서 다루겠다.

필자는 다양한 환경에서 웹개발을 해 보았다.

 

웹 랭퀴지 선택에서 각각의 장단점이 있다.

리눅스 환경이므로 PHP, JSP 을 선택하라고 애기하고 싶다.

C에 익숙한 분들은 PHP,  자바에 익숙한 분은 JSP 환경의 tomcat을 선택하시면 된다.

디비는 mysql 을 추천한다 가볍고 빠르다. 무료이다. 그리고 한글화된 문서가 있다.

 

컴파일 해서 설치할수도 있겠지만,

간단하게 설치 할수 있는 방법으로 진행하겠다.

 

아파치 서버를 설치합니다

$ sudo apt-get install apache2

 

MySQL Database를 설치합니다.

$ sudo apt-get install mysql-server mysql-client


 PHP를 설치하자

$ sudo apt-get install php5 php5-common libapache2-mod-php5


 

 

 

아파치 DocumentRoot 는 아래와 같이변경하시면된다.

 

pi 계정으로 로그인해서. 아파치 DocumentRoot 로 사할  폴더를 만들고,

mkdir  /home/pi/www

 

해당 폴더를 권한를 755로 변경한다.

chmod  755 /home/pi/www

 

그리고 index.php 파일을 만들고, 아래와 같은 내용을 생성한다.

vi /home/pi/www/index.php

--------- index.php 인용 ----

<?
phpinfo();
?>

--------- index.php 인용 ----


아래와 같은 방법으로,아파치 설정을 변경해서 /var/www 에서 /home/pi/www로 변경하자.


root@raspberrypi:~# cd /etc/apache2/sites-enabled
root@raspberrypi:/etc/apache2/sites-enabled# ls
000-default
root@raspberrypi:/etc/apache2/sites-enabled# vi 000-default

----------- 000-default 파일 변경 ----------

<VirtualHost *:80>
        ServerAdmin webmaster@localhost
        DocumentRoot /home/pi/www
        <Directory />
                Options FollowSymLinks
                AllowOverride None
        </Directory>
        <Directory /home/pi/www/>
                Options Indexes FollowSymLinks MultiViews
                AllowOverride None
                Order allow,deny
                allow from all
        </Directory>

.................

..................
----------- 000-default 파일 변경 ----------


 

 

아파치 설정이 끝났으면, 아래의 명령어로 아파치를 리스타트하자.

sudo /etc/init.d/apache2 restart

 

내부아이피를 이용해서 웹브라우저로 접속하면 아래 화면과 같이 나오면 , 정상적으로 설치된거다.

사용자에 따라 내부아이피 변경는 변경될수 있고,

필자는 고정아이피를 설정했다. 아래 링크 참고.


라즈베리파이 2 무선랜 아이피 고정하기

http://ilikesan.com/entry/라즈베리파이-2-무선랜-아이피-고정하기


iptime 할당 된 내부 아이피 알아내기.

http://ilikesan.com/entry/iptime-할당-된-내부-아이피-알아내기


 

 

 

See you Again ^^ 

 

 

 

 

  1. Ju 2015.10.30 01:52 신고

    똑같이 따라하고 있는데 한가지 의문이 들어서 질문드립니다.
    php 설치하는 명령에서 보시면은 첨부된 스크린샷에도 그렇고 E: php-common 패키지를 찾을수 없다고 적혀있습니다... 즉 설치가 전혀 진행이 안되는데요... 명령어에 혹 잘못 쓰여진게 아닌지 궁금합니다.

  2. aaa 2015.12.10 22:53 신고

    똑같이 해도 안됨....

  3. 오타낫네 2016.01.07 22:06 신고

    php-common 이 아니라 php5-common 입니다 ^^

    • Favicon of http://ilikesan.tistory.com BlogIcon 산좋아해 2016.01.08 18:40 신고

      감사합니다. 수정해 놓았습니다.
      설치시 putty에서 실행 시켜보고, 명령어 복사해서 넣었는데,
      다시 한번 확인해 봐야겠네요.

  4. Favicon of http://nhs0912.tistory.com BlogIcon nhs0912 2016.01.16 15:08 신고

    라즈베리 파이 2에 오라클 DB 도 가능할까요??

  5. 질문드려요 2017.03.14 19:39 신고

    Forbidden
    You don't have permission to access / on this server.
    오류가 발생합니다.
    모두 설치했는데 달랐던부분은
    <VirtualHost *:80>
    ServerAdmin webmaster@localhost
    DocumentRoot /home/pi/www 여기 수정하고,

    여기부턴 아래와같은 내용이 전혀없어 추가해줬습니다.
    <Directory />
    Options FollowSymLinks
    AllowOverride None
    </Directory>
    <Directory /home/pi/www/>
    Options Indexes FollowSymLinks MultiViews
    AllowOverride None
    Order allow,deny
    allow from all
    </Directory>

    저장후엔 리스타트도 했습니다.

방수형 온도센서 DB18B20 회로구성과 ,

라즈베리파이 기반에서 파이썬을 이용해 온도을 출력하는 프로그램에 대한 강좌을 할까 합니다.


아래 링크 정말 잘 정리되어 있습니다. 하지만 영문이죠? 핵심만 뽑아서 설명하도록 하겠습니다.

해도 한번 꼭 가서 보시기 바랍니다.

https://learn.adafruit.com/downloads/pdf/adafruits-raspberry-pi-lesson-11-ds18b20-temperature-sensing.pdf

 

브레드보드 연결 하는 법은 아래 그림을 참고하세요.

  

 그림을 보면 빨간색선은 3.3V 전압에 연결되어 있고, 

파란색선 그라운드에  이고,

노란색선은 온도 데이타를 전송 받는 선입니다.

저항은 3.3V 에서 4.7K-10K 을 쓰면 되는데, 4.7k가 정석이고 10k도 정상 동작되는 것은 확인했습니다.

 

아래 이미지는 방수형 온도센서 연결한 사진입니다.

위의 회로도와 크게 다르지는 않습니다. 어차피 같은 센서를 이용하는 제품이라 동일 합니다.


 

 

 

 

DS18B20는  특별한 1-wire 직렬 인터페이스 제어 로직 온도 센서 자체 포함 되어 있다고 합니다.


DB18B20은 칩에서 디지털신호로 노란선을 통해서 디지털  데이타를 보냅니다.

그 데이타를 하나의 디바이스로 인식 시키면 데이터값을 일종의 디바이스롤 인식해서 온도값을 가져올수 있다.


아날로그로 온도값을 입력받을 수 있는 센서의 경우는,

라즈베리파이는 별도의 장치가 필요하다.

그이유는 라즈베리파이는 아두이노처럼 ADC(아날로그 디지털 변환기)을  포함하고 있지 못해서,

자세한 내용은 아래 링크 참고.

http://blog.naver.com/warit/10190221742

 


온도센서 값을 읽기 위해 설정하는 법에 대해서 다르겠다.

 

Root 권한으로 라즈베리 관련 설정파일 맨 밑에

/boot/config.txt

아래와 같이 추가하고 리부팅(sudo reboot)해주세요.

dtoverlay=w1-gpio

 

리부팅하고 나서 아래와 같은 명령어를 입력하자.

sudo modprobe w1-gpio

sudo modprobe w1-therm


아래의 명령어로 디렉토리를 이동해 보면 두개의 디렉토리가 있다.

cd /sys/bus/w1/devices

-------------- 인용 ----------------

pi@raspberrypi /sys/bus/w1/devices $ ls -la
total 0
drwxr-xr-x 2 root root 0 May 13 06:16 .
drwxr-xr-x 4 root root 0 May 13 06:16 ..
lrwxrwxrwx 1 root root 0 May 13 06:16 28-02150015bcff -> ../../../devices/w1_bus_master1/28-02150015bcff
lrwxrwxrwx 1 root root 0 May 13 06:16 w1_bus_master1 -> ../../../devices/w1_bus_master1
-------------- 인용 ----------------

 

28-XXXX 로 시작되는 폴더로  이동해서 "w1-slave" 파일의 내용을 확인해 보면,

t=22187 부분이 온도를 나타낸다.  해당 값을 1/1000으로 처리하면 22.187도라는 온도가 나온다.

 

-------------- 인용 ----------------

pi@raspberrypi /sys/bus/w1/devices $ cd 28*
pi@raspberrypi /sys/bus/w1/devices/28-02150015bcff $ cat w1_slave
63 01 55 00 7f ff 0c 10 ec : crc=ec YES
63 01 55 00 7f ff 0c 10 ec t=22187

-------------- 인용 ----------------

 

 

 

센서가 제대루 작동하는지 간단한 방법은 테스트 할수 있다.

온도센서 부분을 손으로 잡으면 인용과 같이 온도가 천천히 올라간다.

-------------- 인용 ----------------
pi@raspberrypi /sys/bus/w1/devices/28-02150015bcff $ cat w1_slave
63 01 55 00 7f ff 0c 10 ec : crc=ec YES
63 01 55 00 7f ff 0c 10 ec t=22187
pi@raspberrypi /sys/bus/w1/devices/28-02150015bcff $ cat w1_slave
91 01 55 00 7f ff 0c 10 4d : crc=4d YES
91 01 55 00 7f ff 0c 10 4d t=25062
pi@raspberrypi /sys/bus/w1/devices/28-02150015bcff $ cat w1_slave
9d 01 55 00 7f ff 0c 10 72 : crc=72 YES
9d 01 55 00 7f ff 0c 10 72 t=25812
pi@raspberrypi /sys/bus/w1/devices/28-02150015bcff $ cat w1_slave
c5 01 55 00 7f ff 0c 10 45 : crc=45 YES
c5 01 55 00 7f ff 0c 10 45 t=28312
pi@raspberrypi /sys/bus/w1/devices/28-02150015bcff $ cat w1_slave
dd 01 55 00 7f ff 0c 10 3b : crc=3b YES
dd 01 55 00 7f ff 0c 10 3b t=29812
pi@raspberrypi /sys/bus/w1/devices/28-02150015bcff $

-------------- 인용 ----------------


 

파이썬언어를 이용해서 온도를 출력하는 프로그램을 작성하겠다.


 

아래는 소스파일 첨부

ds18b20.py

 

 

 

 

필자는 파이썬 프로그램에 대해서 전혀 모른다.

하지만, 포트란,BASIC,펄, C, 자바,php, 기타 등등에 대한 경험을 해보았다.

그래서 이정도 간단한 프로그램  딱보면 감으로 알겠다.


import 를 이용해서 프로그램에 필요한 라이블러리를 블려들인다.

os.system을 이용해서 시스템 명령어를 실행하고,

그밑에는 온도센스의 데이타가 들어 있는, 폴더와 파일에 대해서 선언 되어 있다.


그밑에 두개의 함수가  선언 되어 있는데.

read_temp_raw 함수는  온도센서의 값이 들어 있는 파일을 읽어 들어 문자열로 리턴한다.


read_temp 함수는 read_tem_raw 함수를 호출해서 문자열을 리턴 받고,

온도값이 들어있는 부분 "t=" 뒷 부분을 기준으로 문자열을 배열로 나누고,

그값은 temp_string에 저장한다.

temp_c는 섭씨(C) 온도를 저장하고,

temp_f는  화씨(F) 온도를 저장한 변수이다.

두 온도값은 리턴해준다.

 

일종의 메인프로그램에서 (C에서main)

read_temp 함수를 호출해서 온도값을 리턴받아 1초 간격으로 출력해준다.

 

 

실행해 보면 아래와 같다.


 sudo python ds18b20.py

 

 

 

끝까지 읽어주셔서 감사합니다.


 

다음 포스트는 웹프로그래밍(PHP)을 이용해서 온도센서의 값을 읽어들여  DB(Mysql)에 저장하는 법에 대해서 강좌 하겠다.


 

 

  1. BlogIcon 하소 2015.08.20 15:57 신고

    안녕하세요 라즈베리 초보입니다. 님 블러그 보고 열공하고있습니다. ㅎㅎ ㄳㄳ
    온도센서를 따라하는 도중에 cd /sys/bus/w1/devices폴더로 이동하려니 bus 폴더안에 w1이라는 하위 폴더가 저는 없던데 만들어야하는건가요? 아님 원래 있는데 저만 없는건가요? 너무 초보라 한번 막히니 멘붕이네요 ㅜㅜ

    • Favicon of http://ilikesan.tistory.com BlogIcon 산좋아해 2015.08.27 10:25 신고

      온도센서를 인식하지 못하는 것 같습니다.
      설정 부분 다시 확인해 보시구요.
      Root 권한으로 라즈베리파이 관련 설정 다시확인해 보시고요.
      브레인보드쪽 연결 확인해 보세요.
      그래도 안 되면, 아래의 메뉴얼 번역하면서 확인해보세요 ^^
      https://learn.adafruit.com/downloads/pdf/adafruits-raspberry-pi-lesson-11-ds18b20-temperature-sensing.pdf

  2. 김하경 2015.09.05 00:19 신고

    안녕하세요 강좌 너무쉽게 설명되어있어서 넘 좋아요
    한가지 궁금한게 있는데 아파치 웹서버에서 PHP 웹페이지에 GPIO GPIO21 핀의 상태값을 받을수 있는가요?
    <?php
    $re=exec("cat /sys/bus/w1/devices/28-00043e55b9ff/w1_slave" );
    echo "<font style=font-size:30pt align=center> 온도값 : $re </font> " ;
    ?>

    이렇게 온도값을 받고 있는데

    혹시 이렇게 GPIO 상태값 1 or 0 을 받을수 있는가요?

    <?php
    $re=exec("cat /sys/class/gpio/gpio21/value" ) ;
    echo "<font style=font-size:30pt align=center> 상태값 : $re </font> " ;
    ?>

    테스트 해보니깐 빈화면만 출력되네요 권한문제인가요 어떻게 해야하나요 도와주세요

  3. BlogIcon 나그네 2015.11.08 20:29 신고

    먼저 정확하게 온도계를 설치하고
    modprobe w1-gpio
    modprobe w1-therm을 치면 자동으로 만들어지는 것들입니다.

라즈베리파이용 온도센서를 찾다, 방수형 DS18B20 알리익스플레스를 통해서 구매했습니다.

개당 2천원 선 아주아주 착한 가격.

2-3 주동안 인내하면 싼 가격에 구매할수 있습니다.

링크 공개 하겠습니다. 본인은 중국 판매자와 아무관계 없습니다.

http://www.aliexpress.com/snapshot/6596771410.html?orderId=66739600462047


국내에서도 싸게 파는 곳 있네요. 지마켓입니다. 

http://gmkt.kr/goUWXs


 

 

 

 

상품설명  해석으로 대신 하겠다.

-------------------------------------------------

Probe DS18B20 temperature sensor chip using original

DS8B20는  방수 온도 센서 칩을 사용한다.

 

High quality stainless steel pipe anti- rust waterproof package

고품질 스테인레스 파이프는 방수로 녹이 생기지 않는다. 

 
Stainless steel housing (6 * 50mm), lead length 100cm

스테인레스 부분은 (6 * 50mm)이고, 전체길이는 일미터

 
fter rigorous testing each probe individually wrapped

각 상품들은 엄격한 상품 테스트를 받았다.

 
3.0V ~ 5.5V power supply

3.0V~5.5v 전압에서 지원한다.

 
9 to 12 adjustable resolution

9~12개  해결 가능하다

 
Temperature range -55 ° ~ +125 °

온도 측정범위  -55 ° ~ +125 °

 
No external components , the unique single- bus interface
외부 부품 없이 독특한 단일 버스 인터페이스로 동작한다.

 

Output leads : Red (VCC), yellow (DATA), black (GND) (may be have other color,but the output not change)

빨간선은 VCC 이고 노란선은 DATA 전송, 검정색은 GND 그라운이다. (다른 색깔일수도 있지만, output은 변경되지 않는다.)  

-------------------------------------------------

 

그리고 온도 편차에 대해 안 나와 있는데, 대략 +- 0.5도 이다.


아래의 링크로 가보시면, 파이썬 언어 기반에 대한 자세한 강좌를 볼수 있습니다. 

https://learn.adafruit.com/downloads/pdf/adafruits-raspberry-pi-lesson-11-ds18b20-temperature-sensing.pdf

 

DS18B20에 사용법에 대해서 다루겠다.



라즈베리파이2에서 국가 시간을 선택하는 방법을 다루겠다.

 

1. root로 로그인
pi@raspberrypi ~ $ su -

 

2.raspi-config 실행

root@raspberrypi:~# raspi-config

3. 4번 4 Internationalisation Options 국가별 옵션 선택 

 

4. I2 Change Timezone 선택 

 

5. Asia 선택

 

 

6. Seoul 선택하고 ok 누르면 성공 참 쉽죠~

 

7. 시간 확인은 date 명령어로 해보시고 핸드폰 시간과 일치하면 정상입니다.

 

 

ssh로 root 계정으로 로그인 하고,
아래와 같이 vi을 이용해서 네트워크 정보를 수정해 주세요.
vi /etc/network/interfaces

 

아래와 같이 리부팅하게 되면, "192.168.0.30" 으로 아이피가 고정됩니다.

reboot

 


---------  /etc/network/interfaces 원본 ----------------
auto lo

iface lo inet loopback
iface eth0 inet dhcp

allow-hotplug wlan0
iface wlan0 inet manual
wpa-roam /etc/wpa_supplicant/wpa_supplicant.conf
iface default inet dhcp

---------  /etc/network/interfaces 원본 ----------------

---------  /etc/network/interfaces 수정 ----------------
auto lo

iface lo inet loopback
iface eth0 inet dhcp

allow-hotplug wlan0
iface wlan0 inet manual
wpa-roam /etc/wpa_supplicant/wpa_supplicant.conf
iface default inet static
address 192.168.0.30
netmask 255.255.255.0
gateway 192.168.0.1

---------  /etc/network/interfaces 수정 ----------------

 

 

 


 

  1. BlogIcon 김선영 2015.06.06 20:14 신고

    여기에 있는 interfaces원본이 정말 원본인가요? 무선랜이랑 이것저것 건들다보니 지금 interfaces가 양이 많아진 상태인데요... 이게 다른거 수정안한 원본이라면 그대로 가지고 와서 덮어쓰기를 하고 싶은 상황입니다. !

    • Favicon of http://ilikesan.tistory.com BlogIcon 산좋아해 2015.06.08 16:54 신고

      네 원본 맞습니다. 복구용으로 쓰시면 됩니다.
      아래 참고하세요.
      http://askubuntu.com/questions/214170/whats-the-default-etc-network-interfaces

+ Recent posts