18道Shell高級(jí)編程企業(yè)實(shí)戰(zhàn)題及參考答案

1幢妄、監(jiān)控MySQL主從同步

企業(yè)面試題1:監(jiān)控MySQL主從同步是否異常包各,如果異常曾雕,則發(fā)送短信或者郵件給管理員见芹。提示:如果沒(méi)主從同步環(huán)境,可以用下面文本放到文件里讀取來(lái)模擬:

  • 階段1:開(kāi)發(fā)一個(gè)守護(hù)進(jìn)程腳本每30秒實(shí)現(xiàn)檢測(cè)一次。
  • 階段2:如果同步出現(xiàn)如下錯(cuò)誤號(hào)(1158,1159,1008,1007,1062)鸯乃,則跳過(guò)錯(cuò)誤鲸阻。
  • 階段3:請(qǐng)使用數(shù)組技術(shù)實(shí)現(xiàn)上述腳本(獲取主從判斷及錯(cuò)誤號(hào)部分)

模擬文本

[root@oldboy~]# mysql -uroot-p'oldboy' -S /data/3307/mysql.sock -e "show slavestatus\G;"
*************************** 1.row ***************************
               Slave_IO_State:Waiting formaster to send event
                  Master_Host:10.0.0.179   #當(dāng)前的mysql master服務(wù)器主機(jī)
                  Master_User: rep
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File:mysql-bin.000013
         Read_Master_Log_Pos: 502547
               Relay_Log_File:relay-bin.000013
                Relay_Log_Pos:251
        Relay_Master_Log_File:mysql-bin.000013
             Slave_IO_Running:Yes
           Slave_SQL_Running: Yes
              Replicate_Do_DB:
         Replicate_Ignore_DB: mysql
          Replicate_Do_Table:
      Replicate_Ignore_Table:
     Replicate_Wild_Do_Table:
Replicate_Wild_Ignore_Table:
                   Last_Errno: 0
                   Last_Error:
                 Skip_Counter: 0
         Exec_Master_Log_Pos: 502547
              Relay_Log_Space:502986
              Until_Condition:None
               Until_Log_File:
                Until_Log_Pos: 0
          Master_SSL_Allowed: No
          Master_SSL_CA_File:
          Master_SSL_CA_Path:
              Master_SSL_Cert:
           Master_SSL_Cipher:
               Master_SSL_Key:
       Seconds_Behind_Master: 0   #和主庫(kù)比同步延遲的秒數(shù),這個(gè)參數(shù)很重要
Master_SSL_Verify_Server_Cert: No
                Last_IO_Errno: 0
                Last_IO_Error:
               Last_SQL_Errno: 0
               Last_SQL_Error:

腳本
                             
[root@shell scripts]# vicheck_mysql_slave.sh
#!/bin/sh
#oldboy linux training
#2015-05-17
#說(shuō)明:本腳本來(lái)自老男孩linux21期學(xué)員張耀開(kāi)發(fā)缨睡!
# Source function library.
. /etc/init.d/functions
  
# Defined variables
MysqlUser=root
MysqlPass=oldboy123
MysqlPort=3307
Mysqlsock=/data/$MysqlPort/mysql.sock
ErrorNo=(1158 1159 1008 10071062)
errorlog=/tmp/error_skip.log
MysqlCmd="/application/mysql/bin/mysql-u$MysqlUser -p$MysqlPass -S $Mysqlsock"
  
# Judge mysql server is ok?
[ -S $Mysqlsock ] ||{
    echo "Maybe MySQL have sometingwrong"
    exit 1
}
  
# Defined skip error Functions
function error_skip(){
    local flag
    flag=0
    for num in ${ErrorNo[@]}
      do
        if [ "$1" == "$num"];then
           $MysqlCmd -e'stop slave;set globalsql_slave_skip_counter=1;start slave;'
           echo "$(date +%F_%R) $1">>$errorlog
        else
           echo "$(date +%F_%R) $1">>$errorlog
           ((flag++))
        fi
    done
    [ "$flag" =="${#ErrorNo[@]}" ] &&{
        action "MySQL Slave"/bin/false
        uniq $errorlog|mail -s "MySQLSlave is error" 12345678@qq.com
    }
}
  
# Defined check slave Functions
function check_slave(){
    MyResult=`$MysqlCmd -e'show slavestatus\G'|egrep '_Running|Behind_Master|SQL_Errno' |awk '{print $NF}'`
    array=($MyResult)
    if [ "${array[0]}" =="Yes" -a "${array[1]}" == "Yes" -a"${array[2]}" == "0" ]
      then
        action "MySQL Slave"/bin/true
    else
error_skip ${array[3]}
    fi
}
  
# Defined main Functions
function main(){
    while true
       do
         check_slave
         sleep 60
    done
}
main

2鸟悴、批量創(chuàng)建文件及改名

企業(yè)面試題2:使用for循環(huán)在/oldboy目錄下通過(guò)隨機(jī)小寫10個(gè)字母,批量創(chuàng)建10個(gè)html文件奖年,名稱例如為:

[root@oldboy oldboy]# sh/server/scripts/oldboy.sh
[root@oldboy oldboy]# ls -l
total 0
-rw-r--r-- 1 root root 0 Apr 1511:34 coaolvajcq_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1511:34 gmkhrancxh_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1511:34 jdxexendbe_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1511:34 qcawgsrtkp_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1511:34 qnvuxvicni_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1511:34 tmdjormaxr_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1511:34 ugaywanjlm_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1511:34 vfrphtqjpc_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1511:34 vioesjmcbu_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1511:34 wzewnojiwe_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1511:34 xzzruhdzda_oldboy.html

請(qǐng)用至少兩種方法實(shí)現(xiàn)细诸,將以上文件名中的oldboy全部改成oldgirl(用for循環(huán)實(shí)現(xiàn)),并且html改成大寫。

2.1批量創(chuàng)建腳本
[root@shell scripts]# vitouch2.sh 
#!/bin/bash
Path=/oldboy
[ -d $Path ] || mkdir $Path
  
for i in `seq 10`
  do
     char=`echo $RANDOM|md5sum|cut -c 2-11|tr[0-9] [a-j]`
     touch $Path/${char}_oldboy.html
done
[root@shell scripts]# shtouch2.sh   
[root@shell scripts]# ll -h/oldboy/
total 0
-rw-r--r-- 1 root root 0 Apr 1107:49 aeddbiacdj_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1107:49 bccbacghba_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1107:49 bdhijefefb_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1107:49 bhfghjcgaa_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1107:49 ddaacedijc_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1107:49 ebcbbfabaf_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1107:49 ecafccebbi_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1107:49 egcdafafad_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1107:49 iehfcgfaef_oldboy.html
-rw-r--r-- 1 root root 0 Apr 1107:49 ifddfaaicd_oldboy.html

2.2批量改名
[root@shell scripts]# vimv2.sh    
#!/bin/bash
Path=/oldboy
[ -d $Path ] && cd $Path
for file in `ls`
 do
     mv $file `echo $file|sed -e"s#oldboy#oldgirl#g" -e "s#html#HTML#g" `
done
[root@shell scripts]# sh mv2.sh
[root@shell scripts]# ll -h/oldboy/
total 0
-rw-r--r-- 1 root root 0 Apr 1107:49 aeddbiacdj_oldgirl.HTML
-rw-r--r-- 1 root root 0 Apr 1107:49 bccbacghba_oldgirl.HTML
-rw-r--r-- 1 root root 0 Apr 1107:49 bdhijefefb_oldgirl.HTML
-rw-r--r-- 1 root root 0 Apr 1107:49 bhfghjcgaa_oldgirl.HTML
-rw-r--r-- 1 root root 0 Apr 1107:49 ddaacedijc_oldgirl.HTML
-rw-r--r-- 1 root root 0 Apr 1107:49 ebcbbfabaf_oldgirl.HTML
-rw-r--r-- 1 root root 0 Apr 1107:49 ecafccebbi_oldgirl.HTML
-rw-r--r-- 1 root root 0 Apr 1107:49 egcdafafad_oldgirl.HTML
-rw-r--r-- 1 root root 0 Apr 1107:49 iehfcgfaef_oldgirl.HTML
-rw-r--r-- 1 root root 0 Apr 1107:49 ifddfaaicd_oldgirl.HTML
  
  
[root@shell scripts]# vimv3.sh    
#!/bin/bash
Path=/oldboy
[ -d $Path ] && cd $Path
for file in `ls`
 do
     mv $file `echo${file/oldboy.html/oldgirl.HTML}`
done
[root@shell scripts]# sh mv3.sh
[root@shell scripts]# ll -h/oldboy/            
total 0
-rw-r--r-- 1 root root 0 Apr 1108:12 abcaeacdbe_oldgirl.HTML
-rw-r--r-- 1 root root 0 Apr 1108:12 affabgbccg_oldgirl.HTML
-rw-r--r-- 1 root root 0 Apr 1108:12 badbifffbg_oldgirl.HTML
-rw-r--r-- 1 root root 0 Apr 1108:12 ccbcifibbe_oldgirl.HTML
-rw-r--r-- 1 root root 0 Apr 1108:12 cchbacgegb_oldgirl.HTML
-rw-r--r-- 1 root root 0 Apr 1108:12 cdfbjfdiib_oldgirl.HTML
-rw-r--r-- 1 root root 0 Apr 1108:12 chjechdgab_oldgirl.HTML
-rw-r--r-- 1 root root 0 Apr 1108:12 ghibcfcbee_oldgirl.HTML
-rw-r--r-- 1 root root 0 Apr 1108:12 icafaafbdb_oldgirl.HTML
-rw-r--r-- 1 root root 0 Apr 1108:12 igiijhbebj_oldgirl.HTML

3陋守、批量創(chuàng)建用戶隨機(jī)密碼

企業(yè)面試題3:批量創(chuàng)建10個(gè)系統(tǒng)帳號(hào)oldboy01-oldboy10并設(shè)置密碼(密碼為隨機(jī)8位字符串)震贵。

[root@shell scripts]# viuseradd.sh
#! /bin/bash
. /etc/init.d/functions
  
Path=/server/scripts
UserDb=$Path/user.db
FailDb=$Path/fail_user.db
  
[ -d "$Path" ] || mkdir-p $Path
[ -f "$UserDb" ] ||touch $UserDb
[ -f "$FailDb" ] ||touch $FailDb
  
for n in $(seq -w 10)
 do
    passwd=`echo $(date+%t%N)$RANDOM|md5sum|cut -c 2-9`
    useradd oldboy$n >&/dev/null&& user_status=$?
    echo "$passwd"|passwd --stdinoldboy$n >&/dev/null && pass_status=$?
    if [ $user_status -eq 0 -a $pass_status -eq0 ];then
       action "adduser oldboy$n"/bin/true
       echo -e "user:\toldboy$npass:$passwd" >>$UserDb
    else
       action "adduser oldboy$n"/bin/false
       echo -e "user:\toldboy$npass:$passwd" >>$FailDb
    fi
done
[root@shell scripts]# shuseradd.sh           
adduser oldboy01                                          [  OK  ]
adduser oldboy02                                          [  OK  ]
adduser oldboy03                                          [  OK  ]
adduser oldboy04                                          [  OK  ]
adduser oldboy05                                          [  OK  ]
adduser oldboy06                                          [  OK  ]
adduser oldboy07                                           [ OK  ]
adduser oldboy08                                          [  OK  ]
adduser oldboy09                                          [  OK  ]
adduser oldboy10                                          [  OK  ]
[root@shell scripts]# cat user.db
user:   oldboy01 pass:f3291720
user:   oldboy02 pass:457a9f30
user:   oldboy03 pass:ff186389
user:   oldboy04 pass:8f884b7c
user:   oldboy05 pass:26f831b4
user:   oldboy06 pass:344e2300
user:   oldboy07 pass:0736b278
user:   oldboy08 pass:67c1fa76
user:   oldboy09 pass:b11e7aa9
user:   oldboy10 pass:9e0c3673

4、判斷網(wǎng)絡(luò)主機(jī)存活

企業(yè)面試題4:寫一個(gè)腳本嗅义,實(shí)現(xiàn)判斷10.0.0.0/24網(wǎng)絡(luò)里屏歹,當(dāng)前在線用戶的IP有哪些(方法有很多)

#!/bin/sh
for n in `seq 254`
do
  ping -c1 10.0.0.$n &>/dev/null
  if [ $? -eq 0 ]
  then
      echo "10.0.0.$n is up ">>/tmp/uplist.log
  else
      echo "10.0.0.$n is down ">>/tmp/downlist.log
  fi
done

5隐砸、解決DOS攻擊生產(chǎn)案例

企業(yè)實(shí)戰(zhàn)題5:請(qǐng)用至少兩種方法實(shí)現(xiàn)之碗!寫一個(gè)腳本解決DOS攻擊生產(chǎn)案例。

提示:根據(jù)web日志或者或者網(wǎng)絡(luò)連接數(shù)季希,監(jiān)控當(dāng)某個(gè)IP并發(fā)連接數(shù)或者短時(shí)內(nèi)PV達(dá)到100褪那,即調(diào)用防火墻命令封掉對(duì)應(yīng)的IP,監(jiān)控頻率每隔3分鐘式塌。防火墻命令為:iptables-AINPUT -s 10.0.1.10 -j DROP博敬。

[root@shell scripts]# vi dos.sh
#!/bin/bash
  
log=/tmp/tmp.log
  
[ -f $log ] || touch $log
  
function add_iptables(){
    whileread line
        do
          ip=`echo $line|awk '{print $2}'`
          count=`echo $line|awk '{print $1}'`
            if [ $count -gt 100 ] && [`iptables -L -n|grep "$ip"|wc -l` -lt 1 ]
             then
                iptables -I INPUT -s $ip -jDROP
                echo "$line isdropped" >>/tmp/droplist.log
            fi
        done<$log
}
  
  
function main(){
    whiletrue
           do
             #awk '{print $1}' access.log|grep-v "^$"|sort|uniq -c >$log
             netstat -an|grep EST|awk -F '[:]+' '{print $6}'|sort|uniq -c >$log
             add_iptables
             sleep 180
    done
}
  
main

6、MySQL啟動(dòng)腳本

企業(yè)實(shí)戰(zhàn)題6:開(kāi)發(fā)mysql多實(shí)例啟動(dòng)腳本峰尝。

已知mysql多實(shí)例啟動(dòng)命令為:

mysqld_safe--defaults-file=/data/3306/my.cnf&

停止命令為:

mysqladmin -u root -poldboy123 -S /data/3306/mysql.sockshutdown

請(qǐng)完成mysql多實(shí)例啟動(dòng)啟動(dòng)腳本的編寫偏窝。

要求:用函數(shù),case語(yǔ)句武学、if語(yǔ)句等實(shí)現(xiàn)祭往。

[root@shell scripts]# vi mysqld1.sh
#!/bin/bash
# chkconfig: 2345 65 37
# description: manager multiplemysqld server.
  
# Warning: This script uses the/etc/init.d/functions system function.
#          System  kernel version isCentOS6.6,2.6.32-504.el6.x86_64.
#          I'm not sure whether other systemscan be used normally.
# Source function library.
. /etc/init.d/functions
  
  
Port=$2
datadir=/data/$2
Path="/application/mysql"
CmdPath="$Path/bin"
MysqlCmd="$CmdPath/mysqld_safe"
prog=mysqld
Port=$2
datadir=/data/$2
pidfile=${PIDFILE-$datadir/mysqld.pid}
lockfile=${LOCKFILE-/var/lock/subsys/mysqld$Port}
MysqlConf="$datadir/my.cnf"
RETVAL=0
  
Usage1(){
        echo -e "\033[33m USAGE: $0 {startport|stop port|status port|restart port} \033[0m"
        exit 6
}
  
Usage2(){
        echo -e "\033[33m MySQL DaemonProgram Need Configuration File,like $datadir/my.cnf \033[0m"
        exit 6
}
  
[ -n "$Port" -a  -z "`echo"${Port//[0-9]/}"`" ] || Usage1
  
start(){
        [ -x $MysqlCmd ] || exit 5
        [ -f $MysqlConf ] || Usage2
        echo -n $"Starting $prog: "
        daemon --pidfile=${pidfile}"$MysqlCmd --defaults-file=$MysqlConf &>/dev/null &"
        sleep 1
        RETVAL=$?
        echo
        [ $RETVAL = 0 ] && touch${lockfile}
        return $RETVAL
}
  
stop(){
        echo -n $"Stopping $prog: "
        killproc -p $pidfile
        retval=$?
        echo
        [ $retval -eq 0 ] && rm -f${lockfile}
        return $retval
}
  
restart() {
        stop
        sleep 1
        start
}
  
rh_status() {
        status -p $pidfile
}
  
rh_status_q() {
        rh_status >/dev/null 2>&1
}
  
case "$1" in
    start)
        rh_status_q && exit 0
        $1
        ;;
    stop)
        rh_status_q || exit 0
        $1
        ;;
    restart)
        $1
        ;;
    status)
        rh_status
        ;;
    *)
        Usage1
        exit 2
esac

7、分庫(kù)備份

企業(yè)實(shí)戰(zhàn)題7:如何實(shí)現(xiàn)對(duì)MySQL數(shù)據(jù)庫(kù)進(jìn)行分庫(kù)備份火窒,請(qǐng)用腳本實(shí)現(xiàn)硼补。

[root@shell scripts]# vifenku_backup.sh 
#!/bin/bash
MysqlUser=root
PassWord=oldboy123
Port=3306
Socket="/data/$Port/mysql.sock"
MysqlCmd="mysql -u$MysqlUser-p$PassWord -S $Socket"
Database=`$MysqlCmd -e "showdatabases;"|egrep -v "Database|_schema|mysql"`
MysqlDump="mysqldump-u$MysqlUser -p$PassWord -S $Socket"
IP=`ifconfig eth0|awk -F "[:]+" 'NR==2 {print $4}'`
BackupDir=/backup/$IP
  
[ -d $BackupDir ] || mkdir -p$BackupDir
  
  
for dbname in $Database
  do
     $MysqlDump --events -B $dbname|gzip>/$BackupDir/${dbname}_$(date +%F)_bak.sql.gz
done
[root@shell 10.0.0.3]# ls
chongtu_2015-04-11_bak.sql.gz  oldboy_2015-04-11_bak.sql.gz  test_2015-04-11_bak.sql.gz
mysql_2015-04-11_bak.sql.gz    qqqqqq_2015-04-11_bak.sql.gz

8、分庫(kù)分表備份

企業(yè)實(shí)戰(zhàn)題8:如何實(shí)現(xiàn)對(duì)MySQL數(shù)據(jù)庫(kù)進(jìn)行分庫(kù)加分表備份熏矿,請(qǐng)用腳本實(shí)現(xiàn)已骇。

[root@shell scripts]# vifenbiao_backup.sh
#!/bin/bash
MysqlUser=root
PassWord=oldboy123
Port=3306
Socket="/data/$Port/mysql.sock"
MysqlCmd="mysql -u$MysqlUser-p$PassWord -S $Socket"
Database=`$MysqlCmd -e "showdatabases;"|egrep -v "Database|_schema|mysql"`
MysqlDump="mysqldump-u$MysqlUser -p$PassWord -S $Socket"
IP=`ifconfig eth0|awk -F "[:]+" 'NR==2 {print $4}'`
BackupDir=/backup/$IP
  
[ -d $BackupDir ] || mkdir -p$BackupDir
  
  
for dbname in $Database
  do
     [ ! -d /$BackupDir/$dbname ] &&mkdir -p /$BackupDir/$dbname
     TABLE=`$MysqlCmd -e "show tables from$dbname;"|sed '1d'`
     for table in $TABLE
        do
          $MysqlDump $dbname $table|gzip>/$BackupDir/$dbname/${dbname}_${table}_$(date +%F).sql.gz
     done
done

9离钝、打印字母數(shù)不大于6的單詞

企業(yè)面試題9: bash for循環(huán)打印下面這句話中字母數(shù)不大于6的單詞(昆侖萬(wàn)維面試題)。

Iam oldboy teacher welcome to oldboy training class.

請(qǐng)用至少兩種方法實(shí)現(xiàn)褪储!

[root@shell scripts]# vi length.sh
#!/bin/bash
  
echo "-------wc -L----"
for word in I am oldboy teacherwelcome to oldboy training class.
  do
     if [ `echo ${word}|wc -L` -le 6 ]
     then
        echo $word
     fi
done
  
echo"-----{#word}-----"
for word in I am oldboy teacherwelcome to oldboy training class.
  do
     if [ ${#word} -le 6 ]
     then
        echo $word
     fi
done
  
  
echo "-----exprlength-----"
for word in I am oldboy teacherwelcome to oldboy training class.
  do
     if [ `expr length "$word"` -le 6]
     then
        echo $word
     fi
done
  
echo"-----{word:0:6}-----"
for word in I am oldboy teacherwelcome to oldboy training class.
do
    if [ "$word" =="${word:0:6}" ]
     then
        echo $word
    fi
done
  
echo "-----awk-----"
echo "I am oldboy teacherwelcome to oldboy training class"|awk '{for(i=1;i<=NF;i++)if(length($i)<=6)print $i}'
  
echo "-----awk2-----"
echo -n "I am oldboy teacherwelcome to oldboy training class." | awk 'BEGIN {RS=FS} length($0)<=6{print $0}'
  
  
echo "-----數(shù)組-----"
arr=(I am oldboy teacher welcometo oldboy training class.)
for word in ${arr[@]}
do
  if [ ${#word} -le 6 ]
  then
      echo $word
  fi
done
  
echo-----------------------------
for((i=0;i<${#arr[*]};i++))
do
    if [ ${#arr[$i]} -le 6 ]
    then
       echo ${arr[$i]}
    fi
done
[root@shell scripts]# shlength.sh  
-------wc -L----
I
am
oldboy
to
oldboy
class.
-----{#word}-----
I
am
oldboy
to
oldboy
class.
-----expr length-----
I
am
oldboy
to
oldboy
class.
-----{word:0:6}-----
I
am
oldboy
to
oldboy
class.
-----awk-----
I
am
oldboy
to
oldboy
class
-----awk2-----
I
am
oldboy
to
oldboy
class.
-----數(shù)組-----
I
am
oldboy
to
oldboy
class.
-----------------------------
I
am
oldboy
to
oldboy
class.
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末卵渴,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子鲤竹,更是在濱河造成了極大的恐慌奖恰,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,270評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件宛裕,死亡現(xiàn)場(chǎng)離奇詭異瑟啃,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)揩尸,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,489評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門伞辛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人合冀,你說(shuō)我怎么就攤上這事恭金。” “怎么了勇边?”我有些...
    開(kāi)封第一講書人閱讀 165,630評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵犹撒,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我粒褒,道長(zhǎng)识颊,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 58,906評(píng)論 1 295
  • 正文 為了忘掉前任奕坟,我火速辦了婚禮祥款,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘月杉。我一直安慰自己刃跛,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,928評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布苛萎。 她就那樣靜靜地躺著桨昙,像睡著了一般。 火紅的嫁衣襯著肌膚如雪腌歉。 梳的紋絲不亂的頭發(fā)上蛙酪,一...
    開(kāi)封第一講書人閱讀 51,718評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音究履,去河邊找鬼滤否。 笑死,一個(gè)胖子當(dāng)著我的面吹牛最仑,可吹牛的內(nèi)容都是我干的藐俺。 我是一名探鬼主播炊甲,決...
    沈念sama閱讀 40,442評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼欲芹!你這毒婦竟也來(lái)了卿啡?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,345評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤菱父,失蹤者是張志新(化名)和其女友劉穎颈娜,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體浙宜,經(jīng)...
    沈念sama閱讀 45,802評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡官辽,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,984評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了粟瞬。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片同仆。...
    茶點(diǎn)故事閱讀 40,117評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖裙品,靈堂內(nèi)的尸體忽然破棺而出俗批,到底是詐尸還是另有隱情,我是刑警寧澤市怎,帶...
    沈念sama閱讀 35,810評(píng)論 5 346
  • 正文 年R本政府宣布岁忘,位于F島的核電站,受9級(jí)特大地震影響区匠,放射性物質(zhì)發(fā)生泄漏干像。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,462評(píng)論 3 331
  • 文/蒙蒙 一辱志、第九天 我趴在偏房一處隱蔽的房頂上張望蝠筑。 院中可真熱鬧,春花似錦揩懒、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,011評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至辅愿,卻和暖如春智亮,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背点待。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,139評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工阔蛉, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人癞埠。 一個(gè)月前我還...
    沈念sama閱讀 48,377評(píng)論 3 373
  • 正文 我出身青樓状原,卻偏偏與公主長(zhǎng)得像聋呢,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子颠区,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,060評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,180評(píng)論 25 707
  • 《老男孩Linux運(yùn)維》筆記MySQL-Documentation 概述 MySQL介紹 MySQL屬于傳統(tǒng)關(guān)系型...
    Zhang21閱讀 1,007評(píng)論 0 9
  • 我不是個(gè)特別矯情的人 但不可避免的削锰,像每個(gè)文科生,像每個(gè)女生一樣毕莱,我會(huì)適時(shí)的發(fā)一些話器贩。 可能在你看來(lái),這是些無(wú)聊的...
    厶一閱讀 397評(píng)論 0 0
  • 在微信朋截,看到兩個(gè)視頻蛹稍。 第一個(gè)是奶茶的后來(lái),現(xiàn)場(chǎng)版部服。很多人都說(shuō)自己的青春是周杰倫稳摄,想了想自己,我的青春饲宿,好像更多的...
    時(shí)七qaq閱讀 306評(píng)論 0 2
  • L Day2完結(jié)后隔了很長(zhǎng)時(shí)間厦酬,才開(kāi)始寫3。斷斷續(xù)續(xù)瘫想,每天幾句仗阅,總算拼湊完成。其實(shí)有時(shí)看了都不知道自己在說(shuō)什么国夜,更...
    Kellyyen閱讀 178評(píng)論 0 1