EasySwoole 使用*.ini格式的配置文件

EasySwoole 使用*.ini格式的配置文件

简介

本文章带领大家学习如何在EasySwoole使用ini格式的配置文件。

ini的优缺点

优点:线性的、简单、简练、方便

缺点:复杂类型的数据配置无力

目录结构

.
├── App
│   ├── HttpController
│   │   └── Productor.php
│   ├── Process
│   │   └── Consumer.php
│   └── Resource
│       └── RedisPool.php
├── Config
│   └── Ini
│       ├── database.ini
│       └── redis.ini
├── EasySwooleEvent.php
├── Ini
│   └── src
│       └── Ini.php
xxx

Ini包源码

非常简单

<?php
/**
 * @CreateTime:   2020/5/3 下午6:30
 * @Author:       huizhang  <tuzisir@163.com>
 * @Copyright:    copyright(2020) Easyswoole all rights reserved
 * @Description:  解析ini配置文件
 */
namespace EasySwoole\Ini;

use EasySwoole\Component\Singleton;
use EasySwoole\EasySwoole\Config;
use EasySwoole\Spl\SplArray;

class Ini
{
    use Singleton;

    protected $iniDir;

    public function __construct()
    {
        $this->iniDir = Config::getInstance()->getConf('INI_DIR');
    }

    public function setDir($iniDir)
    {
        $this->iniDir = $iniDir;
        return $this;
    }

    public function getConf(string $fileName, $key)
    {
        return $this->parseConf($fileName, $key);
    }

    private function parseConf($fileName, $key)
    {
        $config = parse_ini_file($this->iniDir.'/'.$fileName.'.ini', true);

        if ($key == null) {
            return $config;
        }

        if (empty($key)) {
            return null;
        }
        if (strpos($key, '.') > 0) {
            $temp = explode('.', $key);
            if (is_array($config)) {
                $data = new SplArray($config);
                return $data->get(implode('.', $temp));
            }
        }

        return $config[$key];
    }
}

配置文件格式

database.ini

; 订单数据库
[order]
host=127.0.0.1
port=3306
user=admin
password=123456
database=order

; 用户数据库
[user]
host=127.0.0.1
port=3306
user=admin
password=123456
database=user

配置Ini配置文件的默认目录

配置ini文件的目录有两种方式

1. 在EasySwoole的配置文件中,比如dev.php
<?php
return [
    'SERVER_NAME' => "EasySwoole",
    'MAIN_SERVER' => [
        xxx
    ],
    'INI_DIR' => EASYSWOOLE_ROOT.'/Config/Ini' // 指定ini配置文件的目录
];
2. 在mainServerCreate方法中注册
public static function mainServerCreate(EventRegister $register)
{
    Ini::getInstance()->setDir(EASYSWOOLE_ROOT.'/Config/Ini');
}

使用方式

// 获取database.ini中的所有配置
Ini::getInstance()->getConf('database');

// 获取database.ini中的一块配置
Ini::getInstance()->getConf('database', 'order');

// 获取database.ini中的一块配置的某一项
Ini::getInstance()->getConf('database', 'order.host');

EasySwoole

官网:http://www.easyswoole.com

交流群:932625047

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于 Veins 中的信道选择算法,你需要在 omnetpp.ini 文件中手动添加相应的配置参数来设置。具体来说,你需要添加以下参数: ``` *.**.nic.phy80211p.radioMedium.defaultChannelNumber = 178 *.**.nic.phy80211p.radioMedium.numChannels = 3 *.**.nic.phy80211p.radioMedium.channelWidth = 10MHz *.**.nic.phy80211p.radioMedium.transmitterPower = 20mW *.**.nic.phy80211p.radioMedium.carrierFrequency = 5.890e+9Hz *.**.nic.phy80211p.radioMedium.alpha = 2.0 *.**.nic.phy80211p.radioMedium.carrierFrequency2 = 5.895e+9Hz *.**.nic.phy80211p.radioMedium.alpha2 = 2.0 *.**.nic.phy80211p.radioMedium.thresholddBm = -82 *.**.nic.phy80211p.radioMedium.pathLossMap = xmldoc("pathloss.xml") *.**.nic.phy80211p.radioMedium.shadowingMap = xmldoc("shadowing.xml") *.**.nic.phy80211p.radioMedium.obstacleLossMap = xmldoc("obstacleLoss.xml") *.**.nic.mac1609_4.useServiceChannel = true *.**.mac1609_4.serviceChannel = 172 *.**.mac1609_4.useBeaconFrequency = true *.**.mac1609_4.beaconFrequency = 10 ``` 其中,`*.**.nic.phy80211p.radioMedium.defaultChannelNumber` 设置默认的信道号,`*.**.nic.phy80211p.radioMedium.numChannels` 设置信道总数, `*.**.nic.phy80211p.radioMedium.channelWidth` 设置信道带宽, `*.**.nic.mac1609_4.useServiceChannel` 和 `*.**.mac1609_4.serviceChannel` 用于设置使用的服务信道和频率, `*.**.mac1609_4.useBeaconFrequency` 和 `*.**.mac1609_4.beaconFrequency` 用于设置使用的信标频率。 除此之外,你还可以在 omnetpp.ini 文件中添加其他的配置参数来设置不同的信道选择算法,如自适应功率控制(APC)和自适应调制和编码(AMC)等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值