Category Archives: Source

PowershellでMySQLにアクセス

psmysql.sh
#[void][System.Reflection.Assembly]::LoadWithPartialName(“MySql.Data”)
[void][system.Reflection.Assembly]::LoadFrom(“C:\Program Files (x86)\MySQL\MySQL Connector Net 6.5.4\Assemblies\v4.0\MySql.Data.dll”)
$Server=”127.0.0.1″
$Database=”testps”
$user=”powershell”
$Password=”XXX
$charset=”utf8″
$connectionString = “server=$Server;uid=$user;pwd=$Password;database=$Database;charset=$charset”
$connection = New-Object MySql.Data.MySqlClient.MySqlConnection
$connection.ConnectionString = $connectionString
$sql= “SELECT * FROM product_details”
$command = New-Object MySql.Data.MySqlClient.MySqlCommand($sql, $connection)
$dataAdapter = New-Object MySql.Data.MySqlClient.MySqlDataAdapter($command)
$ds = New-Object System.Data.DataSet
$recordCount = $dataAdapter.Fill($ds)
Write-Host ‘総計:’ $recordCount ‘個レコード’

#収集データの表示
Write-Host ‘$ds.Tables’
$ds.Tables

#カラム名を検索
Write-Host ‘カラム名下記:’
foreach($table in $ds.Tables)
{
foreach($column in $table.Columns)
{
$column.ColumnName
}
}

#すべてのデータをポーリング
Write-Host ‘ポーリングデータ:’
foreach($table in $ds.Tables)
{
foreach($row in $table.Rows)
{
$curRow = ”
foreach ($column in $table.Columns)
{
$curRow += [string]$row[$column] + ‘ ‘
}
$curRow
}
}

Write-Host ‘配列アクセス:’
#配列方法でカラム名を取得
$ds.Tables[0].columns[0].columnname
#配列を介してデータをインデックス
$ds.Tables[0].rows[0][1]

Tomcatを再起動する用シェルスクリプト

機能:
自動的に現在実行中のTomcatのPIDを取得し、プロセスをkillした後、Tomcatを再起動する。

reatarttomcat.sh
#!/bin/sh
tomcatpath=”/usr/local/tomcat-6.0.18/”
tomcatname=”tomcat-6.0.18″
tomcatsh=”tomcat6.sh”

if [ $# -ne 1 ]; then
ps -ef | grep java | grep ${tomcatpath};
pid=$(ps -ef | grep java | grep ${tomcatpath} | awk ‘{print $2}’)
else
pid=$1
fi

echo -e ” ${tomcatpath}開始前, 動いているプロセスは殺されて,pidをkillする ${pid} (yes/no)? \c”
read Confirm

case $Confirm in
y|Y|yes|Yes)
rm -rf ${tomcatpath}work/Catalina/localhost/*
kill -9 $pid
rm -f ${tomcatpath}${tomcatname}.pid
sleep 1
/etc/init.d/${tomcatsh} start; tail -f ${tomcatpath}logs/catalina.out
;;
*)
echo ” ${tomcatpath}の再起動動作はキャンセルされた”
;;
esac

Shellでいくつかの特定ファイル以外のすべてのファイルを削除する

コマンド:
rm `ls *.log | grep -vE “aaa\.log|bbb\.log”`

grepのパラメータはEを追加して、eではなくです。前者は拡張正規表現をサポートする、-vは逆マッチの意味です。

コマンドラインでoracleを起動

コマンド:
#su – oracle
$sqlplus / as sysdba
>startup
>exit
$lsnrctl start
$ps -ef|grep oracle

rpmパッケージを完全にアンインストール用スクリプト

rpmuninstall.sh

#!/bin/bash
#######################################################
PACKAGE=$1

RPM_OPS=”-e”
#######################################################
if [ “$1” = “” ]

then

echo “usage : $0 package –rpmops=[/’opts/’]”

echo “example: $0 ant –rpmops=’–test -e'”

exit 1

fi

#######################################################

while [ ! “$1” = “” ]

do

shift

arg=$1

if [ “${arg:0:8}” = “–rpmops” ]

then

RPM_OPS=”${arg:9:100}”

fi

done

function show_depends()

{

local _PACKAGE=”$1″

local _INDENT=”$2″

DEPS=`rpm –test -e $_PACKAGE 2>&1|grep needed|awk ‘{print $NF}’`

for depends in $DEPS

do

echo “$_INDENT $depends”

show_depends “$depends” “$_INDENT””–”

done

}

####rpmをアンインストールする###
function rpm_do_erase()

{

local _PACKAGE=”$1″

local _INDENT=”$2″

DEPS=`rpm $RPM_OPS $_PACKAGE 2>&1|grep needed|awk ‘{print $NF}’`

for depends in $DEPS

do

echo “erase $_INDENT $depends”

rpm_do_erase “$depends” “$_INDENT””–”

if [ ! “$?” = 0 ]

then

echo “作業 $_INDENT $depends 失敗した”

fi

done

}

echo “show depends graph:”

echo “$PACKAGE”

show_depends $PACKAGE “–”

echo “本当に $_PACKAGE (y/n)をアンインストールするか?”

read yn

if [ “$yn” = “y” ]

then

rpm_do_erase $PACKAGE “–”

else

echo ” $PACKAGEのアンインストールをキャンセルする”

fi

Ubuntu 11.04で LibreOffice 3.4.3をインストール

手順:
sudo add-apt-repository ppa:libreoffice/ppa
sudo apt-get update
sudo apt-get upgrade

LibreOfficeのダウンロード:
http://www.libreoffice.org/download/

linux上で定時にMongoDBからデータのエクスポート

目的:CSV形式でのMongoDBになるためにデータをエクスポートできるようwにシェルスクリプトを書く。
要求:
1.莫大な量のデータをエクスポートすることためを防ぐ、当月と先月のデータを濾過しなかればならないだけが良いです。
2.当日のデータが完備していないため、だから当日のデータを排除しなければなりません。
使い方:
1.下記コードを.shファイルで保存する
2.chmod+xでファイルの実行権限を与える
3.crontabコマンドを使ってシナリオをプラスして定時タスクに着く

run.sh
run.sh

#!/bin/bash
#ディレクトリを作成して保存する
mypath=micAnalyDir/`date +%Y/%m%d`
mkdir -p $mypath

#濾過時間を計算
baseDate=`date –date ‘1 months ago’ +’%m/01/%Y’`
echo $baseDate
declare -i baseTime
baseTime=$((`date –date “$baseDate” +”%s”` * 1000))

#データテーブルで指定されたデータをエクスポート
function exportData() {
exportCmd=”/kingdee/mongodb/bin/mongoexport –csv”
if [ $# -gt 3 ]; then
#ここはbasetimeとendTimeは引用符号を使わないので注意してください
$exportCmd -d $1 -c $2 -f $3 -q \
“{\”$4\”:{\”\$gte\”:{\”\$date\”:$baseTime}, \
\”\$lt\”:{\”\$date\”:$endTime}}}” -o $mypath/$2.csv
else
$exportCmd -d $1 -c $2 -f $3 -o $mypath/$2.csv
fi
}

#最初データテーブルのすべてのデータをエクスポート
echo export data from $baseDate
echo ‘export ossDev.T_User’
fields=”_id,email,registerDate,photoId”
exportData “ossDev” “T_User” $fields

#第二テーブルのsendTimeは今月と先月のデータ
echo ‘export snsDev.T_Comment’
fields=”_id,del,from,mbId,mbOwner,nwId,ownerId,sendTime”
exportData “snsDev” “T_Comment” $fields “sendTime”

Synapticsのタッチパッドを無効、有効する

touch.sh
#!/bin/bash

if [ $(synclient -l | grep TouchpadOff | awk -F ‘= ‘ ‘{ print $2 }’) -eq 0 ]; then
synclient TouchpadOff=1
else
synclient TouchpadOff=0
fi

詳しくはhttps://wiki.archlinux.org/index.php/Touchpad_Synaptics

CentOS環境でapacheと SVNをインストールする

#!/bin/sh

########ソースコードパッケージをダウンロード##########
wget http://subversion.tigris.org/downloads/subversion-1.6.15.tar.gz;
wget http://subversion.tigris.org/downloads/subversion-deps-1.6.15.tar.gz;
wget http://mirror.bjtu.edu.cn/apache/httpd/httpd-2.2.21.tar.gz;
wget http://archive.apache.org/dist/apr/apr-1.4.2.tar.gz
wget http://archive.apache.org/dist/apr/apr-util-1.3.10.tar.gz

########ソースコードパッケージをダウンロード##########
yum -y install gcc* openssl-devel expat-devel openssl openssl-devel libxml2-devel glibc-common gd-devel;

########コンパイルインストール##############

########aprのインストール#########
tar zxvf apr-1.4.2.tar.gz;
cd apr-1.4.2;
./configure –prefix=/usr/local/apr;
make;
make install;
cd ..;

########apr-utilのインストール########

tar zxvf apr-util-1.3.10.tar.gz;
cd apr-util-1.3.10;
./configure –with-apr=/usr/local/apr;
make;
make install;
cd ..;

########apacheのインストール########

tar zxvf httpd-2.2.21.tar.gz
cd httpd-2.2.21;
./configure –prefix=/usr/local/apache –enable-dav –enable-so –enable-maintainer-mode –with-apr=/usr/local/apr/bin/apr-1-config –with-apr-util=/usr/local/apr/bin/apu-1-config;
make;
make install;
cd ..;

########subversionのインストール########

tar zxvf subversion-1.6.15.tar.gz;
tar zxvf subversion-deps-1.6.15.tar.gz;
cd subversion-1.6.15;
./configure –prefix=/usr/local/subversion –with-apxs=/usr/local/apache/bin/apxs –with-apr=/usr/local/apr –with-apr-util=/usr/local/apr –without-berkeley-db;
make;
make install;
cd ..;

###################################################

ルートディレクトリに実行可能ファイルを出力する

rootoutput.sh

#!/bin/bash
for yh in `ls /root`
do
if [ -x $yh ]
then
echo $yh

fi

done