#!/bin/sh /etc/rc.common

# Copyright (C) 2008-2012 OpenWrt.org

#启动顺序

START=90

#创建PID文件

SERVICE_USE_PID=1

find_release_info()

{

    [ -s /etc/openwrt_release ] && . /etc/openwrt_release

[ -z "$DISTRIB_DESCRIPTION" ] && [ -s /etc/openwrt_version ] && \

DISTRIB_DESCRIPTION="$(cat /etc/openwrt_version)"

echo "${DISTRIB_DESCRIPTION:-Unknown OpenWrt release} @ $(cat /proc/sys/kernel/hostname)"

}

# 启动

start() {

#需要调用network.sh中的函数,因此加载文件

. /lib/functions/network.sh

#定义变量

local enable_cdp

local enable_fdp

local enable_sonmp

local enable_edp

local lldp_class

local lldp_location

local lldp_description

#需要从/etc/config/lldpd配置文件中取变量,因此加载文件

config_load 'lldpd'

#从配置文件中将变量读出

config_get_bool enable_cdp 'config' 'enable_cdp' 0

config_get_bool enable_fdp 'config' 'enable_fdp' 0

config_get_bool enable_sonmp 'config' 'enable_sonmp' 0

config_get_bool enable_edp 'config' 'enable_edp' 0

config_get lldp_class 'config' 'lldp_class'

config_get lldp_location 'config' 'lldp_location'

config_get lldp_description 'config' 'lldp_description' "$(find_release_info)"

local ifaces

config_get ifaces 'config' 'interface'

local iface

for iface in $ifaces; do

local ifname=""

if network_get_device ifname "$iface" || [ -e "/sys/class/net/$iface" ]; then

append args "-I ${ifname:-$iface}"

fi

done

[ $enable_cdp -gt 0 ] && append args '-c'

[ $enable_fdp -gt 0 ] && append args '-f'

[ $enable_sonmp -gt 0 ] && append args '-s'

[ $enable_edp -gt 0 ] && append args '-e'

user_exists  lldp 121 || user_add  lldp 121 129

group_exists lldp 129 || group_add lldp 129

#创建文件夹,并加权限

mkdir -p /var/run/lldp

chown lldp:lldp /var/run/lldp

#拉起进程

service_start /usr/sbin/lldpd $args \

${lldp_class:+ -M $lldp_class} \

${lldp_description:+ -S "$lldp_description"}

[ -n "$lldp_location" ] && {

sleep 1

/usr/sbin/lldpctl -L "$lldp_location" > /dev/null 2>&1

}

}

#停止

stop()

{

service_stop /usr/sbin/lldpd

rm -f /var/run/lldpd.socket /var/run/lldpd.pid

}

lldpd启动脚本分析的更多相关文章

  1. HBase配置&启动脚本分析

    本文档基于hbase-0.96.1.1-cdh5.0.2,对HBase配置&启动脚本进行分析 date:2016/8/4 author:wangxl HBase配置&启动脚本分析 剔除 ...

  2. Spark配置&启动脚本分析

    本文档基于Spark2.0,对spark启动脚本进行分析. date:2016/8/3 author:wangxl Spark配置&启动脚本分析 我们主要关注3类文件,配置文件,启动脚本文件以 ...

  3. Hadoop启动脚本分析

    Hadoop启动脚本分析 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 能看到这篇博客的你估计对Hadoop已经有一个系统的了解了,最起码各种搭建方式你应该是会的,不会也没有关系, ...

  4. 4. hadoop启动脚本分析

    4. hadoop启动脚本分析 1. hadoop的端口 ``` 50070 //namenode http port 50075 //datanode http port 50090 //2name ...

  5. busybox rootfs 启动脚本分析(二)

    上次分析了busybox的启动脚本,这次分析一下init.d中一些脚本的内容. 参考链接 http://www.cnblogs.com/helloworldtoyou/p/6169678.html h ...

  6. busybox rootfs 启动脚本分析(一)

    imx6文件系统启动脚本分析.开机运行/sbin/init,读取/etc/inittab文件,进行初始化. 参考链接 http://blog.163.com/wghbeyond@126/blog/st ...

  7. hadoop启动脚本分析及常见命令

    进程------------------ [hdfs]start-dfs.sh NameNode NN DataNode DN SecondaryNamenode 2NN [yarn]start-ya ...

  8. linux系统 initrd.img中init启动脚本分析

    概述:这篇文章主体内容来源于网上转载.前面几篇文章倾向于制作initrd.img,这篇文章更倾向于initrd.img的运行过程:加载framebuff驱动 ide驱动和文件系统驱动,最后进入到真正的 ...

  9. 内核启动文件系统后第一个执行的文件(inittab启动脚本分析)

    Linux 开机脚本启动顺序: 第一步:启动内核 第二步:执行init (配置文件/etc/inittab) 第三步:启动相应的脚本,执行inittab脚本,并且执行里面的脚本/etc/init.d ...

随机推荐

  1. asp.net网站发布到服务器GET的技能

    刚刚知道映射网络驱动器的作用(虽然才知道,但是我高兴) 把服务器上的硬盘或者其他电脑共享给你的盘映射到本地,就和操作本地硬盘一样. 双击计算机->映射网络驱动器->上面选择驱动器号 下面文 ...

  2. Redis配置成系统服务(CentOS7)

    1. 进入到redis安装目录,具体位置看你安装时的路径了. cd /usr/local/redis/ 2. 编辑配置文件 sudo vim ./redis.conf 3. 将如下配置项注释掉 #bi ...

  3. PDF在线阅读 FlexPaper 惰性加载 ;

    关于PDF在线阅读问题,比较普遍的做法是转换成swf文件来浏览:由于项目需要,就用 flexpaper 来实现了下,功能比较简单:但是文件的惰性加载确实让笔者挠头了一把! 下面是笔者的方法: 采用流的 ...

  4. 解决 bootstrap 在IE8下的兼容问题

    <meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="v ...

  5. 【for陷阱】遍历的同时删除元素

    今晚,哦不,是昨晚了,想删除空行时,给for语句和列表坑得好惨!!! 一般来说,删除字符串的空行有以下几种常见的方法~(然而我竟然想不出来) 假设我们要把下面的字符串之间的空行给去掉 # coding ...

  6. iOS 隐藏导航栏 隐藏状态栏

    1导航栏 self.navigationController.navigationBarHidden = YES; 2 状态栏 [[UIApplication sharedApplication] s ...

  7. CNN计算过程

  8. TcpListener 示例

    using System; using System.IO; using System.Net; using System.Net.Sockets; using System.Text; class ...

  9. Hiver 操作 MySQL 导致锁表

    Hadoop 搬迁到新集群后,操作主库 MySQL 导致了锁表...sad 具体锁表时间点  : 2016-1-14 14:31  到   2016-1-14 14:36 之间 在 oradba 的 ...

  10. hibernate 和 jdbc 优缺点对比

    jdbc缺点: 1.编程繁琐,用的try和catch比较多 2.jdbc没有对数据做缓存 3.没有做到面向对象编程 4.sql语句的跨平台性很差 jdbc优点: 效率比较高 hibernate的优点: ...