运维自动化bingo前端

这篇具有很好参考价值的文章主要介绍了运维自动化bingo前端。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

项目目录结构介绍

项目创建完成之后,我们会看到bingo_web项目其实是一个文件夹,我们进入到文件夹内部就会发现一些目录和文件,我们简单回顾一下里面的部分核心目录与文件。

├─node_modules/   # node的包目录,项目运行的依赖包存储目录,package.json和package-lock.json文件中会自动记录了这个目录下所有的包以及包的版本信息,
├─public/  # 静态资源目录,项目中的静态资源(css,js,图片等文件)放在这个文件夹
├─src/       # 主开发目录,要开发的客户端代码文件(单文件组件,css样式、工具函数等等)全部在这个目录下
    ├─assets/  # 静态资源存储目录,与public目录作用类似。
    ├─router/  # 路由存储目录,是我们创建项目的时候,如果选择安装vue-router,就自动会生成这个目录。
    ├─views/   # 组件页面存储目录,就是浏览器中用户看到的页面内容,views往往会加载并包含components中的组件进来
    ├─components/  # 组件存储目录,就是浏览器中用户看到的页面的一部分内容。
    ├─App.vue
    ├─main.js
    └─style.css
├─index.html
└─package.json   #  如果node_modules没有,但是有package.json,则可以在终端下,通过npm install进行恢复node_modules所有内容。

2.3、项目执行流程图

运维自动化bingo前端,前端,vue.js,javascript
要在Vue.js项目中指定域名和端口,你通常需要配置Vue CLI提供的devServer,而不是直接在defineConfig里面指定域名和端口。devServer配置通常用于开发环境,它允许你定义开发服务器的参数,比如端口号、代理设置等。不过,如果你想要在生产环境中配置一个特定的域名和端口,这通常需要在部署到服务器时,通过服务器配置(例如Nginx或Apache)来实现,而不是在Vue CLI的配置中直接设置。

如果你的目的是为了开发环境,想要Vue CLI开发服务器运行在www.bingo.com域名和80端口,你可以试着修改vue.config.js文件(如果文件不存在,你需要手动创建这个文件):

首先,确认你的电脑上hosts文件已经将www.bingo.com指向了127.0.0.1(本地开发环境)。

然后,编辑vue.config.js文件来包含devServer配置,类似下面这样:

const { defineConfig } = require('@vue/cli-service');

module.exports = defineConfig({
  transpileDependencies: true,
  // 配置开发服务器
  devServer: {
    host: 'www.bingo.com', // 指定开发服务器监听的域名
    port: 80, // 指定开发服务器的端口
  },
});

请注意,由于80端口是一个标准的HTTP端口,通常需要管理员权限才能让应用监听在80端口上。在Linux或macOS上,你可能需要使用sudo来启动应用。在Windows上,可能需要以管理员权限运行命令行工具。

此外,使用80端口有可能和系统上已经运行的其他服务发生冲突,确保80端口没有被其他应用占用。

使用www.bingo.com进行项目访问:
运维自动化bingo前端,前端,vue.js,javascript

最后,因为我们是在本地开发环境配置,所以实际上并不会直接影响到生产环境的域名和端口设置。生产环境的域名和端口设置依赖于你的服务器和DNS配置。

在Vue CLI中,vue.config.js是一个可选的配置文件,如果项目的构建和开发过程中需要自定义选项,可以在项目根目录下创建这个文件。vue.config.js提供了很多配置项可以帮助你优化和调整开发以及构建的过程。以下是一些常用的配置项:

  1. publicPath: 类型:string,部署应用包时的基本 URL。用法如下:

    module.exports = {
      publicPath: process.env.NODE_ENV === 'production' ? '/production-sub-path/' : '/'
    }
    
  2. outputDir: 类型:string,构建时生成的生产环境构建文件的目录。默认在项目根目录下生成一个dist目录。用法如下:

    module.exports = {
      outputDir: 'dist'
    }
    
  3. assetsDir: 类型:string,放置生成的静态资源 (js、css、img、fonts) 的目录。相对于outputDir

    module.exports = {
      assetsDir: 'assets'
    }
    
  4. indexPath: 类型:string,指定生成的index.html的输出路径,相对于outputDir

    module.exports = {
      indexPath: 'index.html'
    }
    
  5. filenameHashing: 类型:boolean,默认情况下,生成的静态资源文件名中包含了hash以控制缓存,你可以通过这个选项关闭。

    module.exports = {
      filenameHashing: false
    }
    
  6. pages: 类型:Object,在多页面应用下构建应用。每个“page”应该有一个对应的 JavaScript 入口文件。

    module.exports = {
      pages: {
        index: {
          // page 的入口
          entry: 'src/index/main.js',
          // 模板来源
          template: 'public/index.html',
          // 在 dist/index.html 的输出
          filename: 'index.html',
        },
        // 当使用只有入口的字符串格式时,默认会使用`public/subpage.html`作为模板,如果不存在,则回退到`public/index.html`模板。
        subpage: 'src/subpage/main.js'
      }
    }
    
  7. lintOnSave: 类型:boolean | 'warning' | 'default' | 'error',是否在开发环境下通过 eslint-loader 在每次保存时 lint 代码。这个值会默认取[process.env.NODE_ENV] 的值,是生产构建时禁用。

    module.exports = {
      lintOnSave: process.env.NODE_ENV !== 'production'
    }
    
  8. runtimeCompiler: 类型:boolean,是否使用包含运行时编译器的 Vue 构建版本。设置为 true 后你就可以在 Vue 组件中使用 template 选项了。

    module.exports = {
      runtimeCompiler: true
    }
    
  9. transpileDependencies: 类型:Array<string | RegExp>,默认情况下 babel-loader 会忽略所有 node_modules 中的文件。如果你想要通过 Babel 显式转译一个依赖,可以在这个选项中列出来。

    module.exports = {
      transpileDependencies: [/my-dependency/]
    }
    

这些是vue.config.js中比较常见和有用的配置项。对于更详细的配置和更高级的用法,建议查看Vue CLI官方文档。

安装axios模块
npm install axios --save --registry https://registry.npmjs.org/

view.HomeView.vue内容详解:

<template>
  <div class="home">
    <img alt="Vue logo" src="../assets/logo.png">
    <HelloWorld msg="Welcome to Your Vue.js App"/>
  </div>
</template>

<script>
// @ is an alias to /src
import HelloWorld from '@/components/HelloWorld.vue'

export default {
  name: 'HomeView',
  components: {
    HelloWorld
  }
}
</script>

在 Vue 组件中,name 选项用于指定组件的名称。虽然这个选项不是必须的,但它在某些场景下扮演了重要的角色,提供了以下几个好处:

  1. 调试:当你在开发工具(如 Vue Devtools)中调试应用时,有名字的组件会更容易识别和跟踪。没有名称的组件可能仅显示为 <AnonymousComponent>,这使得调试变得更加困难。

  2. 递归组件:如果一个组件需要在其模板内递归地调用自己,那么为这个组件指定一个 name 是必须的。这样组件就可以通过其名称引用自己,实现递归渲染。

  3. keep-alive<keep-alive> 是 Vue 提供的一个抽象组件,用于保留组件状态或避免重新渲染。在使用 <keep-alive> 时,includeexclude 属性允许你指定哪些组件应该被缓存或忽略。这两个属性接受组件 name 作为参数,因此在这种场景下 name 选项非常有用。

  4. Vue 组件库:在创建可复用的组件库时,为每个组件指定一个 name 选项可以更方便地管理和使用这些组件。特别是在全局注册组件的时候,Vue 将使用组件的 name 选项作为组件的标识。

示例中的 name: 'App' 表示将这个根组件的名称设为 “App”。这对调试非常有帮助,因为如果出现错误或需要在 Vue Devtools 中查看组件层次结构时,你可以轻松找到名为 “App” 的根组件。

总之,name 选项虽不是必须的,但在实践中为组件指定名称是一个好习惯,尤其是在以上提到的几种场景中。它有助于提升代码可读性和维护性,并且在开发、调试以及构建可重用组件时,使得工作流程更加顺畅。

在JavaScript(包括用于开发Vue应用的ES6标准)中,除了export default之外,还有export关键字用于导出模块的其他成员。export defaultexport共同构成了ES6的模块导出机制,它们之间有几个关键的区别:

export default

  • 每个模块可以有一个default导出。
  • 使用export default时,导入时可以为其指定任意名称。
  • 主要用于导出模块的“主要”功能或值。

例如,导出一个函数:

export default function() { console.log("Hello World!"); }

导入时:

import myFunction from './myModule';

export

  • 一个模块可以导出多个(非默认)成员。
  • 导入时需要使用相同的名称,或者使用as关键字重命名。
  • 用于导出一个模块的多个功能或值。

例如,导出多个函数或变量:

export const myConstant = 123;
export function myFunction() { console.log("Hello World!"); }
export class MyClass {}

导入时:

import { myFunction, myConstant, MyClass as RenamedClass } from './myModule';

结合使用export defaultexport:

一个模块中可以同时使用export defaultexport来导出多个成员,其中一个作为默认导出,而其他则作为具名导出。

// myModule.js
export default function() { console.log("Default Function"); }
export function myFunction() { console.log("My Function"); }
export const myConstant = 123;

导入时:

// 引入默认导出的函数,可以任意命名
import defaultFunction, { myFunction, myConstant } from './myModule';

注意事项:

  • export default允许你导出模块时不必使用大括号,而export导出的成员则需要在导入时放在大括号内。
  • 当使用export导出多个成员时,导入这些成员必须使用它们原有的名字,除非使用as关键字进行重命名。
  • export default的主要优势在于简化了默认导出成员的导入语法,因为你不需要使用大括号并且可以自由命名导入的成员。

这种模块化机制极大地增强了JavaScript代码的组织性和可维护性,使开发者可以轻松地在不同的文件和模块之间共享功能和值。

总结 export default与export

  1. export default: 由于每个模块文件只能有一个默认导出,因此在导入时可以随意命名。这意味着无论在导出时成员被命名为什么,在导入时都可以自定义命名,而 JavaScript 会理解你指的是该文件的默认导出成员。这就是为什么export default能使导入语法变得简化和灵活。

  2. export: 允许一个模块导出多个成员。由于可能同时导出多个成员,每个成员都有自己的名字,所以在导入这些成员时需要明确指出导入成员的具体名称。这样做是为了保证明确性和一致性,确保在导入时 JavaScript 知道你指的是哪个具体成员。

    如果需要,在导入时改变名称,可以使用as关键词来重命名,这样做即可以保持导入成员的明确性,又能提供一定程度的灵活性。

综上所述,这两种导出(exportexport default)方式提供了不同级别的灵活性和明确性,以适应不同的使用场景。选择哪一种方式取决于你的具体需求,例如,当模块只提供一个主要功能或值时,使用export default比较方便;而当模块提供多个函数、变量或组件时,使用export可以同时导出它们,使得导入这些成员时更加清晰明确。

从 Vue 3.0 开始,<script setup> 是为了简化组合式 API 的使用而提出的一个编译时语法糖。当使用 <script setup> 时,您不能以传统的方式(export default {})导出组件选项。<script setup> 标签内部的代码被视为组件的顶层代码,因此直接定义变量、函数以及其他响应式状态即可,无需封装在 export default {} 里。

  1. 移除 export default 声明。
  2. 直接在 <script setup> 内部声明组件的逻辑。
  3. 如果需要定义组件的 name,可以通过 defineComponent 的方式。
    将天气预报的代码进行vue-cli的修改
    view.ShowCenter.vue

<template>
  <h1 class="showcenter">Show Center</h1>
  <input type="text" v-model="city"><button @click="getque" class="table-bordered">查询城市天气</button>
  <div>当前查询城市: {{city}}</div>
  <p></p>
  <table  v-if="data1!=''">
    <tr>
      <th>序号</th>
      <th>城市</th>
      <th>日期</th>
      <th>白天天气</th>
      <th>夜间天气</th>
      <th>最高温度</th>
      <th>最低温度</th>
      <th>相对湿度</th>
      <th>能见度</th>

    </tr>
    <tr v-for="(tq,index) in data1">
      <td>{{index+1}}</td>
      <td>{{city}}</td>
      <td>{{tq.fxDate}}</td>
      <td>{{tq.textDay}}</td>
      <td>{{tq.textNight}}</td>
      <td>{{tq.tempMax}}</td>
      <td>{{tq.tempMin}}</td>
      <td>{{tq.humidity}}</td>
      <td>{{tq.vis}}</td>


    </tr>
  </table>
</template>


<script setup>
import { defineComponent, ref, onMounted } from 'vue';
import axios from "axios";

defineComponent({ name: 'show-center' });

// 以 ref 创建响应式变量
const data1 = ref([]);
const id = ref('');
const city = ref('北京');

// 定义获取数据的方法
const getque = async () => {
  try {
    const { data: locationData } = await axios.get(`https://geoapi.qweather.com/v2/city/lookup?location=${city.value}&key=dc7728d14dfb4c6eb3eadc070a5839&lang=zh`);
    console.log(locationData.location);
    // 省略业务逻辑
    city.value = locationData.location[0].name;
    id.value = locationData.location[0].id;
    console.log(data1.value, id.value);

    const { data: weatherData } = await axios.get(`https://devapi.qweather.com/v7/weather/7d?location=${id.value}&key=dc7728d14dfb4c6eb3eadc070a5839&lang=zh`);
    console.log(weatherData.daily);
    data1.value = weatherData.daily;
  } catch(error) {
    console.error("请求时发生错误:", error);
  }
};
// 使用 onMounted 生命周期钩子
onMounted(() => {
  getque();
});
</script>
<style scoped>
table,tr,th,td{
  border: 3px solid red;
  border-collapse: collapse;
}
th ,td{
  width: 200px;
  text-align: center;
  height: 30px;
  line-height: 30px;
}

.co{
  background-color: orange;
}
</style>

在这段代码中,我们通过 defineComponent({ name: 'showcenter' }) 来定义组件名称,使用 ref 创建响应式变量来替代原有的 data(){} 定义方式。函数和生命周期钩子直接定义在 <script setup> 的顶级作用域中,这样既符合 <script setup> 的使用规范,又保持了原有逻辑的完整性。

请注意,当使用 <script setup> 时,组件的大部分功能都可以通过直接在脚本中声明来实现,无需包裹在 export default {} 里。另外,如果您的项目中还未启用 <script setup>,或不打算使用它的特性,建议回归到传统 Vue 组件的写法。

const { data: locationData } = await axios.get(`https://geoapi.qweather.com/v2/city/lookup?location=${city.value}&key=dc7728d14dfb4c6eb3eadc070a5839&lang=zh`);

这行代码使用了几个JavaScript和Vue.js中常见的技术点,包括解构赋值、模板字符串、await关键字以及axios库的使用。下面我会逐一解释这些技术点:

  1. axios库
    axios是一个基于Promise的HTTP客户端,用于浏览器和node.js环境中发送HTTP请求。在这段代码中,axios.get方法用于向指定的URL发送GET请求。

  2. 模板字符串
    使用反引号括起来的字符串称为模板字符串,它允许你在字符串中嵌入变量或表达式。${city.value}这部分代码会被替换为city.value变量的实际值,变量city可能是一个响应式变量,通过Vue的refreactive函数创建。

  3. await关键字
    await关键字用于等待一个Promise对象的结果。它只能在异步函数(通过async定义的函数)中使用。在这里,它用于等待axios.get发送请求并返回响应的过程完成。

  4. 解构赋值
    解构赋值允许你将数组或对象的属性/值“解构”到不同的变量中。在这个例子中,const { data: locationData } = ...从axios返回的响应对象中解构出data属性,并将其重命名为locationData。这意味着你可以直接使用locationData变量访问原响应对象中data属性的值。

综上所述,这行代码的执行流程如下:

  1. 使用axios.gethttps://geoapi.qweather.com/v2/city/lookup发送GET请求,请求参数包括location(其值取自city.value)、key(API密钥)和lang(语言偏好)。
  2. 请求发送后,await会暂停当前异步函数的执行,直到Promise解决并返回响应结果。
  3. axios的Promise解决后,其返回的响应对象中的data属性被解构并赋值给locationData变量。
  4. 现在,locationData包含了从天气API获得的、关于请求位置的信息,可以在后续代码中使用这些数据。

错误处理
通过 try-catch 捕捉错误,但由于 Axios 请求使用的是 Promise(并且被 .then 方法处理),错误不会被 try-catch 捕获到,除非 Axios 请求中使用 await
const getque = async () => {} 是一个使用 ES6 箭头函数语法和 async 关键字定义的异步函数。这个函数可以进行异步操作,比如网络请求、读写文件等不会立即完成的操作,并使用 await 关键字以同步的方式写异步代码。这种语法提供了一种更简洁和直观的方式来处理 JavaScript 中的异步编程。下面将分步骤详细介绍这一语法。

const getque = async () => {}语法详解

1. 箭头函数 (() => {})

箭头函数是一种在 ES6 (ECMAScript 2015) 中引入的简写形式,用于定义函数。与传统的函数定义方式相比,箭头函数提供了更简洁的语法。

  • 基本语法
(parameters) => { statements }

如果函数只有一个参数,可以省略参数周围的括号:

parameter => { statements }

如果函数体只有一条语句,且是返回值的话,可以省略大括号和 return 关键字:

parameter => expression
// 等价于
parameter => { return expression; }
  • 没有自己的 this

箭头函数没有自己的 this 值,它会捕获其所在上下文的 this 值为自己的 this,使得在回调函数中的 this 行为变得更加可预测。

2. async 关键字

async 是一个在函数定义前使用的关键字,表明该函数是异步的。async 函数总是返回一个 Promise 对象。如果 async 函数显式返回一个非 Promise 值,这个值会被自动包裹在一个 Promise 中。

async function myFunction() {
  return 'Hello';
}
myFunction().then(alert); // 弹出 'Hello'

使用箭头函数定义异步函数的形式如下:

const myAsyncFunction = async () => {
  // 异步操作
};

3. await 关键字

async 函数内部,可以使用 await 关键字来等待一个 Promise 完成。它会暂停 async 函数的执行,直到 Promise 完成(即 Promise 被 “resolve” 或 “reject”),然后继续执行 async 函数,并返回结果。

  • 基本用法
const data = await someAsyncOperation();

await 只能在 async 函数内部使用,如果在普通函数中使用 await,会引发语法错误。

总结

const getque = async () => {} 定义了一个名为 getque 的异步函数,该函数内部可以包含异步操作,如进行网络请求或者执行其他返回 Promise 对象的操作。通过 asyncawait 的组合使用,可以以更接近同步编程的方式写出清晰、简洁的异步代码。

route.index.js

import { createRouter, createWebHistory } from 'vue-router'
import HomeView from '../views/HomeView.vue';
import showcenter from  '../views/ShowCenter.vue'

const routes = [
  {
    path: '/',
    name: 'showcenter',
    component: showcenter
  },
  {
    path: '/about',
    name: 'about',
    // route level code-splitting
    // this generates a separate chunk (about.[hash].js) for this route
    // which is lazy-loaded when the route is visited.
    component: () => import(/* webpackChunkName: "about" */ '../views/AboutView.vue')
  }
]

const router = createRouter({
  history: createWebHistory(process.env.BASE_URL),
  routes
})

export default router

实现效果:
运维自动化bingo前端,前端,vue.js,javascript
最终前端展示(部分):
view.base.vue

<template>
  <a-layout style="min-height: 100vh">

    <a-layout-sider v-model:collapsed="collapsed" collapsible>
      <div class="logo"
           style="font-style: italic;text-align: center;font-size: 20px;color:#fff;margin: 10px 0;line-height: 50px;font-family: 'Times New Roman'">
        <!--a-switch是指定开关-->
        <span><a-switch v-model:checked="checked"/> DevOps</span>
      </div>
      <a-menu v-for="list in menu_list"  v-model:selectedKeys="selectedKeys" theme="dark" mode="inline">

        <a-menu-item v-if="list.children.length==0" key="list.id">
          <Myicons :icon="list.icon"></Myicons>
          <!--跳转路由-->
          <span>
            <router-link :to="list.menu_url">{{list.title}}</router-link>
          </span>
        </a-menu-item>

        <a-sub-menu v-else :key="list.id">
          <template #title>
            <span>
              <!--引用子组件components.myicons.vue-->
              <myicons :icon="list.icon"></myicons>
              <span>
                {{list.title}}
              </span>
            </span>
          </template>
          <a-menu-item v-for="children in list.children"  :key="children.id">
            <router-link :to="children.menu_url">{{children.title}}</router-link>
          </a-menu-item>
        </a-sub-menu>

      </a-menu>
    </a-layout-sider>

    <a-layout>
      <a-layout-header style="background: #fff; padding: 0" />
      <a-layout-content style="margin: 0 16px">
        <a-breadcrumb style="margin: 16px 0">
          <a-breadcrumb-item>User</a-breadcrumb-item>
          <a-breadcrumb-item>Bill</a-breadcrumb-item>
        </a-breadcrumb>
        <div :style="{ padding: '24px', background: '#fff', minHeight: '785px' }">
          <router-view/>
        </div>
      </a-layout-content>
      <a-layout-footer style="text-align: center">
        Panda Design ©2024 Created by Ant cong
      </a-layout-footer>
    </a-layout>
  </a-layout>
</template>
<script setup>
import Myicons from "@/components/Myicons.vue";
import {reactive, ref} from 'vue';
const collapsed = ref(false);
const selectedKeys = ref(['1']);
const checked=ref(false);
const menu_list = reactive([
  {
    id: 1, icon: 'settings', title: '系统管理', tube: '', menu_url: '/uricgo/show_center', children: []
  },
  {
    id: 2, icon: 'desktop', title: '资产管理', menu_url: '/uricgo/host', children: []
  },
  {
    "id": 3, icon: 'cloud', title: '批量任务', tube: '', menu_url: '/uricgo/workbench', children: [
      {id: 10, icon: 'mail', title: '执行任务', menu_url: '/uricgo/multi_exec'},
      {id: 11, icon: 'mail', title: '命令管理', menu_url: '/uricgo/template_manage'},
    ]
  },
  {
    id: 4, icon: 'git', title: '代码发布', tube: '', menu_url: '/uricgo/workbench', children: [
      {id: 12, title: '应用管理', menu_url: '/uricgo/release'},
      {id: 13, title: '发布申请', menu_url: '/uricgo/release'}
    ]
  },
  {id: 5, icon: 'history', title: '定时计划', tube: '', menu_url: '/uricgo/workbench', children: []},

  {id: 7, icon: 'monitor', title: '监控预警', tube: '', menu_url: '/uricgo/workbench', children: []},

  {
    id: 9, icon: 'user', title: '用户中心', tube: '', menu_url: '/uricgo/workbench', children: [
      {id: 20, title: '账户管理', tube: '', menu_url: '/uricgo/workbench'},
      {id: 21, title: '角色管理', tube: '', menu_url: '/uricgo/workbench'},
      {id: 22, title: '系统设置', tube: '', menu_url: '/uricgo/workbench'}
    ]
  }
]);
</script>
<style scoped>
#components-layout-demo-side .logo {
  height: 32px;
  margin: 16px;
  background: rgba(255, 255, 255, 0.3);
}

.site-layout .site-layout-background {
  background: #fff;
}
[data-theme='dark'] .site-layout .site-layout-background {
  background: #141414;
}
</style>

route.index.js

import { createRouter, createWebHistory } from 'vue-router'
import showcenter from  '../views/ShowCenter.vue'
import Time from '../views/ShowCenter-backup.vue'
import login from '../views/login.vue'
import base from '../views/base.vue'
import hosts from '../views/hosts.vue'


const routes = [
  {
    path: '/bingo',
    alias:'/',
    name: 'base',
    component: base,
    children:[
      {
        path:"Time",
        alias:"",
        name:"time",
        component: Time
      },
      {
        path:"host",
        name:"host",
        component:hosts
      },
      {
        path:'showcenter',
        name:"showcenter",
        component:showcenter
      },
    ]
  },
    {
        meta: {
            title: '账户登陆'
        },
        path: '/login',
        name: 'Login',
        component: Login // 快捷键:Alt+Enter快速导包
    },
]

const router = createRouter({
  history: createWebHistory(process.env.BASE_URL),
  routes
})

export default router

页面展示效果:
运维自动化bingo前端,前端,vue.js,javascript文章来源地址https://www.toymoban.com/news/detail-828856.html

到了这里,关于运维自动化bingo前端的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Gitlab CI/CD 自动化打包部署前端(vue)项目

    一、虚拟机安装 1.vmware下载 2.镜像下载 3.Ubuntu 4.新建虚拟机 一直点下一步,直到点击完成。 5.分配镜像 二、Gitlab CI/CD 自动化部署项目 1.配置GitLab CI/CD: 2.生成SSH密钥对: 如果尚未生成,请在本地机器上生成一个SSH密钥对: 3.将SSH私钥添加到GitLab: 4.更新GitLab CI/CD配置: 5

    2024年03月13日
    浏览(58)
  • 基于云计算的自动化部署与自动化运维:提高运维效率

    作者:禅与计算机程序设计艺术 随着互联网技术的飞速发展,网站流量日益增长,用户对网站功能及其可用性的需求也越来越高,越来越多的人开始担忧网站的安全和稳定性。因此,如何快速、准确地处理网站故障、迅速恢复网站服务并保障网站高可用,成为企业必须重点关

    2024年02月11日
    浏览(40)
  • Vue.js 学习14 集成H265web.js播放器实现webpack自动化构建

    H265web.js 是一个用于在 Web 浏览器中播放 H.265 视频的 JavaScript 播放器。它支持在浏览器中直接解码 H.265 编码的视频流,提供了高效的视频播放体验。在 Element UI 项目中集成 H265web.js 可以让我们轻松实现 H.265 视频的播放功能。 H265web.js 开源地址: https://github.com/numberwolf/h265web

    2024年03月14日
    浏览(55)
  • 二、搭建前后端分离的自动化测试平台的前端Vue3+Element-plus前端项目

    1、Node获取地址 https://nodejs.org/en/download 一直默认选项安装,安装好了之后,在环境变量中会自动配置Node的地址,可以在cmd中使用 node -v/npm -v命令验证是否下载成功 2、设置Node的配置内容 (1)在安装目录下新建两个文件夹命名为node_cache,和node_global: 其中 node_cache 是作为 缓

    2024年02月06日
    浏览(52)
  • 自动化运维CICD

    目录 概述 为什么持续集成和发布可以提高效率 如何实现 1、在linux服务器安装部署代码仓库 2、安装jenkins 使用shell脚本实现CICD 使用pipeline实现CICD 使用Blue Ocean实现CICD 持续集成(Continuous Integration,CI)和持续发布(Continuous Delivery,CD,又称持续交付)是经常放在一起提及的两

    2024年02月05日
    浏览(45)
  • DevOps?自动化运维!

    by: 雪月三十 DevOps流程图 DevOps是Dev和Ops的结合 Dev(developer开发) Ops(operation运维) 在企业中dev和ops是有一种天然的矛盾,dev要求的是快速迭代,给公司挖掘出商业的价值,而ops则是强调的稳定,不让你如此快的开发,以稳定为主,不希望动代码(if no problem, don’t touch it),所

    2024年02月12日
    浏览(57)
  • Ansible自动化运维

    目录 前言 一、概述 常见的开源自动化运维工具比较 二、ansible环境搭建 三、ansible模块 (一)、hostname模块 (二)、file模块 (三)、copy模块 (四)、fetch模块 (五)、user模块 (六)、group模块 (七)、cron模块 (八)、yum_repository模块 (九)、yum模块 (十)、service模块

    2024年02月09日
    浏览(46)
  • 【自动化运维】playbook剧本

    (1)Tasks:任务,即通过 task 调用 ansible 的模板将多个操作组织在一个 playbook 中运行 (2)Variables:变量 (3)Templates:模板 (4)Handlers:处理器,当changed状态条件满足时,(notify)触发执行的操作 (5)Roles:角色 运行playbook Ansible提供了很多种循环结构,一般都命名为wi

    2024年02月15日
    浏览(34)
  • 自动化运维工具——Ansible

    Ansible是一个基于Python开发的配置管理和应用部署工具,现在也在自动化管理领域大放异彩。它融合了众多老牌运维工具的优点,Pubbet和Saltstack能实现的功能,Ansible基本上都可以实现。 Ansible能批量配置、部署、管理上千台主机。比如以前需要切换到每个主机上执行的一或多个

    2024年02月14日
    浏览(47)
  • 自动化运维工具—Ansible

    Ansible是一个基于Python开发的配置管理和应用部署工具,现在也在自动化管理领域大放异彩。它融合了众多老牌运维工具的优点,Pubbet和Saltstack能实现的功能,Ansible基本上都可以实现。 市面上其他自动化工具:pupet(ruby语言) saltstack(python) chef(C/S模式)等 Ansible能批量配

    2024年02月10日
    浏览(43)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包