主頁 > 資料庫 > Maven創建SSH工程(快速入門)源代碼

Maven創建SSH工程(快速入門)源代碼

2020-10-02 10:41:46 資料庫

一、Maven工程拆分與聚合

1、工程的拆分

一個完整的早期開發好的crm專案,現在要使用maven工程對它進行分析,這個時候就可以將dao拆解出來,形成獨立的工程,同樣service,action也都進行這樣從拆分

2、工程的聚合

在這里插入圖片描述
拆分后的工程之間相互存在依賴
在這里插入圖片描述

3、繼承的理解

類似java當中的類,都是為了消除重復,子類繼承父類,父類里面有的方法和屬性在子類當中就不需要再定義和實作了,使用的時候直接呼叫父類就可以,我們把crm拆分后,有一個父工程,子工程(crm06_dao,crm06_service,crm06_web)要用到的依賴都可以在父工程(crm06)的pox.xml當中先定義好,將來的子工程在開發的時候就不需要再引入坐標了,

4、開發步驟(詳細步驟)

(1)創建maven父工程crm06,打包方式為pom

在這里插入圖片描述

在這里插入圖片描述

在這里插入圖片描述
在這里插入圖片描述

(2)在父工程的基礎上建立子工程(dao層)

在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述

(3)在父工程的基礎上建立子工程(service層)

在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
點擊Finish

可以在crm07的目錄下的pom.xml當中看到父工程下所包含的子工程多了一個
在這里插入圖片描述
在service當中可以看到指向了父工程目錄
在這里插入圖片描述

(4)在父工程的基礎上建立子工程(dao層)

在這里插入圖片描述
在這里插入圖片描述
點擊Finish
在這里插入圖片描述
在這里插入圖片描述
指向對應的父工程
在這里插入圖片描述

(5)在service 層添加依賴

在這里插入圖片描述

(6)在dao下創建介面


在這里插入圖片描述

介面創建成功
在這里插入圖片描述

(7)實作dao的介面

在這里插入圖片描述
實作成功
在這里插入圖片描述

(8)在service下創建介面

在這里插入圖片描述

(9)實作service的介面

在這里插入圖片描述

(10)在實作類當中寫入如下代碼,會發現報錯

在這里插入圖片描述

(11)需要在service當中添加對dao的依賴

在這里插入圖片描述
在這里插入圖片描述
引入地址后,并導包專案將不會報錯

package com.itzheng.crm.service.impl;
import com.itzheng.crm.dao.ICustomerDao;
import com.itzheng.crm.service.ICustomerService;
public class CustomerService implements ICustomerService {
	private ICustomerDao customerDao;
	public void setCustomerDao(ICustomerDao customerDao) {
		this.customerDao = customerDao;
	}
}

(12)web層呼叫service層,在crm07_web當中的pom.xml當中

在這里插入圖片描述
在這里插入圖片描述
同時引入了crm07_dao和crm07_service,在上面配置引入的時候只引入了service因為service依賴于dao所以dao也被引入了進來
在這里插入圖片描述

5、添加struts2的核心jar

在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述

6、查看pom.xml的依賴關系(通過Exclude排除jar包沖突依賴)

在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
只剩下了最高版本
在這里插入圖片描述
pom.xml當中的struct2的配置多了一個配置
在這里插入圖片描述

7、依賴傳遞范圍

子模塊crm06_dao中添加junit的依賴,scope為test,但是在crm06_service中并不能使用junit
在這里插入圖片描述

1、縱坐標:直接依賴 A依賴B,B是A的直接依賴, 在A的pom.xml中添加B的坐標

2、橫坐標:傳遞依賴 B依賴C,C是A的傳遞依賴

3、中間部分:傳遞依賴的范圍,A依賴C的范圍,

(1)撰寫測驗用例在dao當中,在pom.xml當中

在crm07_dao下的pom.xml當中
在這里插入圖片描述

在這里插入圖片描述

(2)service依賴dao但是,在dao引入junit測驗后色service當中沒有,如果想讓junit在業務層也可以呼叫

在crm07_dao當中的pom.xml當中洗掉下面這一句
在這里插入圖片描述
洗掉之后可以在service當中看到junit的jar
在這里插入圖片描述

解決辦法: 如果在依賴傳遞的程序當中,導致jar包的丟失,我們的做法很簡單,就是再匯入一次坐標

8、依賴的兩個原則

(一)第一個原則:第一個先宣告者優先

(1)在父工程當中添加依賴

在這里插入圖片描述

在這里插入圖片描述

在這里插入圖片描述

(2)在crm07/pom.xml當中

在這里插入圖片描述

(3)在pom.xml當中更改一下對應的,兩個spring的順序

在這里插入圖片描述

優先順序會改變
在這里插入圖片描述

(二)第二個原則:路徑近者優先原則

(1)實驗如果上面引入的不是自己合適的,再次引入一個新的

在這里插入圖片描述
生效版本變為后添加的版本
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述

9、版本的鎖定

(1)洗掉dao層當中的junit依賴

在這里插入圖片描述

(2)在父工程當中添加對應的junit

在這里插入圖片描述
在這里插入圖片描述

(3)在子工程下面會自動引入和父工程一樣的junit的jar

在這里插入圖片描述
在這里插入圖片描述

(4)這個時候在上面的會有三個專案有三個junit,

(一)這個時候需要通過版本的鎖定來解決這個問題

在父工程的pom.xml當中、
在這里插入圖片描述

<!-- 添加版本鎖定 -->
	<dependencyManagement>
			<dependencies>
				<dependency>
					<groupId>junit</groupId>
					<artifactId>junit</artifactId>
					<version>4.9</version>
					<scope>test</scope>
				</dependency>
			</dependencies>
	</dependencyManagement>
(二)添加版本鎖定以后

子工程當中的junit的jar會消失

(三)在子工程當中添加junit,選擇對應鎖定版本的junit

在dao當中添加對應的junit
在這里插入圖片描述
在子工程的pom.xml當中
在service當中添加對應的junit

10、整合SSH其他jar包

(1)在crm07/pom.xml當中

在這里插入圖片描述

(2)添加其他SSH相關jar

在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述

在這里插入圖片描述

在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述

11、在crm/pom.xml當中定義版本常量

(1)設定對應的值

在這里插入圖片描述

(2)替換對應的變數Ctrl + F

在這里插入圖片描述
通過定義版本編號常量的方式可以定義替換pom.xml當中的內容
在這里插入圖片描述

12、依賴管理總結

在這里插入圖片描述

13、dao層的開發

(1)crm07_dao

在這里插入圖片描述

package com.itzheng.crm.domain;
import java.io.Serializable;
/**
 * PO(Persistence Object)持久化類
 * 7個規范
 * 1. 公有類
 * 2. 公有無參構造
 * 3. 私有屬性
 * 4. 公有的getter與setter
 * 5. 實作java.io.Serializable介面
 * 6. 不能用final修飾
 * 7. 如果是基礎型別,要使用它的包裝類
 * @author Administrator
 */
package com.itzheng.crm.domain;

import java.io.Serializable;

/**
 * PO(Persistence Object)持久化類 7個規范 1. 公有類 2. 公有無參構造 3. 私有屬性 4. 公有的getter與setter
 * 5. 實作java.io.Serializable介面 6. 不能用final修飾 7. 如果是基礎型別,要使用它的包裝類
 * 
 * @author Administrator
 *
 */
public class Customer implements Serializable {

	private Long cust_id;
	private String cust_name;
	/*
	 * private String cust_source; private String cust_industry; private String
	 * cust_level;
	 */
	private String cust_phone;
	private String cust_mobile;

	private String cust_image;// 客戶資質的圖片

	public Long getCust_id() {
		return cust_id;
	}

	public void setCust_id(Long cust_id) {
		this.cust_id = cust_id;
	}

	public String getCust_name() {
		return cust_name;
	}

	public void setCust_name(String cust_name) {
		this.cust_name = cust_name;
	}

	public String getCust_phone() {
		return cust_phone;
	}

	public void setCust_phone(String cust_phone) {
		this.cust_phone = cust_phone;
	}

	public String getCust_mobile() {
		return cust_mobile;
	}

	public void setCust_mobile(String cust_mobile) {
		this.cust_mobile = cust_mobile;
	}

	public String getCust_image() {
		return cust_image;
	}

	public void setCust_image(String cust_image) {
		this.cust_image = cust_image;
	}

	@Override
	public String toString() {
		return "Customer [cust_id=" + cust_id + ", cust_name=" + cust_name + ", cust_phone=" + cust_phone
				+ ", cust_mobile=" + cust_mobile + ", cust_image=" + cust_image + "]";
	}

}

(2)組態檔(在src/main/resources下創建xml檔案)

a、先創建和dao層一模一樣的包

在這里插入圖片描述

b、在創建好的包當中創建xml檔案

在這里插入圖片描述
撰寫映射檔案

c、創建Hibernate的映射檔案
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC 
	"-//Hibernate/Hibernate Mapping DTD 3.0//EN" 
	"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd" >
<hibernate-mapping>
	<class name="com.itzheng.crm.domain.Customer" table="cst_customer">
		<!-- 建立類中的屬性與表中的主鍵對應 -->
		<id name="cust_id" column="cust_id">
			<!-- 主鍵生成策略 -->
			<generator class="native" />
		</id>
		<!-- 建立類中的普通的屬性和表的欄位的對應映射 -->
		<property name="cust_name" column="cust_name" />
		
		<property name="cust_phone" column="cust_phone" />
		<property name="cust_mobile" column="cust_mobile" />
		<property name="cust_image" column="cust_image" />
    </class>
</hibernate-mapping>

在這里插入圖片描述

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd" >
<hibernate-configuration>
	<session-factory>
		<!-- 方言 -->
		<property name="dialert">org.hibernate.dialect.Oracle11gDialect</property>
		<property name="show_sql">true</property>
		<property name="format_sql">false</property>
		<property name="hbm2ddl.auto">none</property>
		<!-- 懶加載 -->
		<property name="hibernate.enable_lazy_load_no_trans">true</property>
		<!-- 物體類的驗證 -->
		<property name="javax.persistence.validation.mode">none</property>		
	</session-factory>
</hibernate-configuration>
d、創建spring的檔案

在這里插入圖片描述

e、在spring下創建spring的xml映射檔案

在這里插入圖片描述

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
	xmlns:context="http://www.springframework.org/schema/context"
	xmlns:aop="http://www.springframework.org/schema/aop" 
	xmlns:tx="http://www.springframework.org/schema/tx"
	xsi:schemaLocation="
		http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd 
		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd 
		http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd 
		http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd ">		
	<!-- 資料源 -->
	<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">	
		<property name="driverClass" value="com.mysql.jdbc.Driver"></property>		
		<property name="jdbcUrl" value="jdbc:mysql://localhost:3306/crm?characterEncoding=utf-8"></property>
		<property name="user" value="root" ></property>
		<property name="password" value="root" ></property>	
	</bean>	
	<!-- sessionFactory;SessionFactory介面負責初始化Hibernate,它充當資料存盤源的代理,并負責創建Session物件,	-->
	<bean id="sessionFactory" class="org.springframework.orm.hibernate5.LocalSessionFactoryBean">	
		<property name="dataSource" ref="dataSource"></property>		
		<property name="configLocation" value="classpath:hibernate.cfg.xml" ></property>		
		<property name="mappingLocations" value="classpath:com/itzheng/crm/domain/*.hbm.xml" ></property>		
	</bean>	
	<!-- 資料訪問層 -->
	<bean id="customerDao" class="com.itzheng.crm.dao.impl.CustomerDao">
		<property name="sessionFactory" ref="sessionFactory" ></property>	
	</bean>
</beans>
d、完善CustomerDao類
package com.itzheng.crm.dao.impl;
import java.util.List;
import org.springframework.orm.hibernate5.support.HibernateDaoSupport;
import com.itzheng.crm.dao.ICustomerDao;
import com.itzheng.crm.domain.Customer;
public class CustomerDao extends HibernateDaoSupport implements ICustomerDao {	
	public List<Customer> findAll() {	
		return (List<Customer>) getHibernateTemplate().find("from Customer");
	}
}
e、創建好測驗類

在這里插入圖片描述

package com.itzheng.crm.dao.test;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.itzheng.crm.dao.impl.CustomerDao;
public class CustomerTest {
	@Test
	public void tt() {
		ApplicationContext ac = new ClassPathXmlApplicationContext("classpath:spring/applicationContext-dao.xml");
		
		CustomerDao customerDao = (CustomerDao)ac.getBean("customerDao");
		
		System.out.println(customerDao.findAll().size());
		
	}
}

查詢成功
在這里插入圖片描述

14、service層的開發

(1)創建spring檔案

在這里插入圖片描述
在這里插入圖片描述

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
	xmlns:context="http://www.springframework.org/schema/context"
	xmlns:aop="http://www.springframework.org/schema/aop" 
	xmlns:tx="http://www.springframework.org/schema/tx"
	xsi:schemaLocation="
		http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd 
		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd 
		http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd 
		http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd ">
	<bean id="transactionManager" class="org.springframework.orm.hibernate5.HibernateTransactionManager">
		<property name="sessionFactory" ref="sessionFactory"></property>
	</bean>
	<!-- 通知 -->
	<tx:advice id="advice" transaction-manager="transactionManager" >
		<tx:attributes>			
				<tx:method name="add*" propagation="REQUIRED" />
				<tx:method name="save*" propagation="REQUIRED" />
				<tx:method name="update*" propagation="REQUIRED" />
				<tx:method name="delete*" propagation="REQUIRED" />
				<tx:method name="*" read-only="true" />
		</tx:attributes>
	</tx:advice>
	<!-- 切面 -->
	<aop:config>
		<aop:pointcut expression="execution(* com.itzheng.crm.service.impl.*.*(..))" id="myPointCut"/>
		<aop:advisor advice-ref="advice" pointcut-ref="myPointCut" />
	</aop:config>
	<!-- 業務 -->
	<bean id="customerService" class="com.itzheng.crm.service.impl.CustomerService">
		<property name="customerDao" ref="customerDao" ></property>
	</bean>
</beans>

(2)創建測驗類

a、在service/pom.xml當中添加junit的配置

在這里插入圖片描述
在這里插入圖片描述

b、完善dao層的內容
package com.itzheng.crm.dao;
import java.util.List;
import com.itzheng.crm.domain.Customer;
public interface ICustomerDao {
	public List<Customer> findAll();
}

在這里插入圖片描述

package com.itzheng.crm.dao.impl;
import java.util.List;
import org.springframework.orm.hibernate5.support.HibernateDaoSupport;
import com.itzheng.crm.dao.ICustomerDao;
import com.itzheng.crm.domain.Customer;
public class CustomerDao extends HibernateDaoSupport implements ICustomerDao {
	public List<Customer> findAll() {	
		return (List<Customer>) getHibernateTemplate().find("from Customer");
	}
}

在這里插入圖片描述

c、完善業務層的內容
package com.itzheng.crm.service.impl;
import java.util.List;
import com.itzheng.crm.dao.ICustomerDao;
import com.itzheng.crm.domain.Customer;
import com.itzheng.crm.service.ICustomerService;
public class CustomerService implements ICustomerService {
	private ICustomerDao customerDao;
	public void setCustomerDao(ICustomerDao customerDao) {
		this.customerDao = customerDao;
	}
	public List<Customer> findAll() {
		return customerDao.findAll();
	}
}

在這里插入圖片描述

d、創建測驗類

在這里插入圖片描述

(3)在applicationContext-service.xml當中匯入dao層的applicationContext-dao.xml

	<!-- 匯入,僅供測驗用 -->
	<import resource="classpath:spring/applicationContext-dao.xml"/>

在這里插入圖片描述

(4)運行測驗類

package com.itzheng.crm.dao.test;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.itzheng.crm.dao.impl.CustomerDao;
public class CustomerTest {
	@Test
	public void tt() {
		ApplicationContext ac = new ClassPathXmlApplicationContext("classpath:spring/applicationContext-dao.xml");	
		CustomerDao customerDao = (CustomerDao)ac.getBean("customerDao");	
		System.out.println(customerDao.findAll().size());
	}
}

在這里插入圖片描述

15、web層的開發

(1)在src/main/java下創建CustomerAction

在這里插入圖片描述

(2)創建整個目錄結構

在這里插入圖片描述

(3)創建CustomerAction
package com.itzheng.crm.web.action;
import java.util.List;
import com.itzheng.crm.domain.Customer;
import com.itzheng.crm.service.impl.CustomerService;
import com.opensymphony.xwork2.ActionContext;
public class CustomerAction {	
	private CustomerService customerService;
	public void setCustomerService(CustomerService customerService) {
		this.customerService = customerService;
	}	
	public String list() {	
		//查詢所有
		List<Customer> customerList = customerService.findAll();	
		//所有的客戶資訊都放入到值堆疊當中	
		ActionContext.getContext().put("list", customerList);
		//回傳list.jsp頁面
		return "list";
	}
}
(4)創建list.jsp頁面
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"  %>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<c:forEach  items="${list }" var="customer"  >
	${ customer.cust_id } --> ${ customer.cust_name } <br>
</c:forEach>
</body>
</html>
(5) 創建applicationContext-action.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
	xmlns:context="http://www.springframework.org/schema/context"
	xmlns:aop="http://www.springframework.org/schema/aop" 
	xmlns:tx="http://www.springframework.org/schema/tx"
	xsi:schemaLocation="
		http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd 
		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd 
		http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd 
		http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd ">		
	<bean id="customerAction" class="com.itzheng.crm.web.action.CustomerAction">	
		<property name="customerService" ref="customerService" ></property>
	</bean>
</beans>
(6) 創建applicationContext.xml, 加載所有的spring背景關系
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xmlns:context="http://www.springframework.org/schema/context"
	xmlns:aop="http://www.springframework.org/schema/aop"
	xmlns:tx="http://www.springframework.org/schema/tx"
	xsi:schemaLocation="
		http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd 
		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd 
		http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd 
		http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd ">
	<import resource="classpath:spring/applicationContext-dao.xml" />
	<import resource="classpath:spring/applicationContext-service.xml" />
	<import resource="classpath:spring/applicationContext-action.xml" />
</beans>
(7) 創建struts.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
	"-//Apache Software Foundation//DTD Struts Configuration 2.3//EN"
	"http: // struts.apache.org/dtds/struts-2.3.dtd" >
<struts>
	<package name="default" namespace="/" extends="struts-default">
		<action name="customer_*" class="customerAction" method="{1}">
			<result name="list">/list.jsp</result>
		</action>
	</package>
</struts>

(8) 配置web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xmlns="http://java.sun.com/xml/ns/javaee"
	xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
	version="2.5">
	  

	<!-- spring背景關系組態檔路徑 -->

	<context-param>

		<param-name>contextConfigLocation</param-name>
		<param-value>classpath:applicationContext.xml</param-value>

	</context-param>

	<!-- 加載spring背景關系 -->

	<listener>

		<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>

	</listener>


	<!-- Hibernate lazy load -->
	<filter>
		<filter-name>openSessionInView</filter-name>
		<filter-class>org.springframework.orm.hibernate5.support.OpenSessionInViewFilter</filter-class>
	</filter>
	<filter-mapping>
		<filter-name>openSessionInView</filter-name>
		<url-pattern>/*</url-pattern>
	</filter-mapping>

	<!-- struts2 -->

	<filter>
		<filter-name>struts</filter-name>
		<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>

	</filter>

	<filter-mapping>
		<filter-name>struts</filter-name>
		<url-pattern>/*</url-pattern>

	</filter-mapping>

</web-app>

16、運行專案

訪問成功
在這里插入圖片描述

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/148014.html

標籤:其他

上一篇:多執行緒核心知識總結(三)——執行緒停止,中斷總結

下一篇:Kotlin從入門到跑路(一)

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:33:24 more
  • MySQL中binlog備份腳本分享

    關于MySQL的二進制日志(binlog),我們都知道二進制日志(binlog)非常重要,尤其當你需要point to point災難恢復的時侯,所以我們要對其進行備份。關于二進制日志(binlog)的備份,可以基于flush logs方式先切換binlog,然后拷貝&壓縮到到遠程服務器或本地服務器 ......

    uj5u.com 2023-04-20 08:28:06 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:27:27 more
  • 快取與資料庫雙寫一致性幾種策略分析

    本文將對幾種快取與資料庫保證資料一致性的使用方式進行分析。為保證高并發性能,以下分析場景不考慮執行的原子性及加鎖等強一致性要求的場景,僅追求最終一致性。 ......

    uj5u.com 2023-04-20 08:26:48 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:26:35 more
  • 云時代,MySQL到ClickHouse資料同步產品對比推薦

    ClickHouse 在執行分析查詢時的速度優勢很好的彌補了MySQL的不足,但是對于很多開發者和DBA來說,如何將MySQL穩定、高效、簡單的同步到 ClickHouse 卻很困難。本文對比了 NineData、MaterializeMySQL(ClickHouse自帶)、Bifrost 三款產品... ......

    uj5u.com 2023-04-20 08:26:29 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:25:13 more
  • Redis 報”OutOfDirectMemoryError“(堆外記憶體溢位)

    Redis 報錯“OutOfDirectMemoryError(堆外記憶體溢位) ”問題如下: 一、報錯資訊: 使用 Redis 的業務介面 ,產生 OutOfDirectMemoryError(堆外記憶體溢位),如圖: 格式化后的報錯資訊: { "timestamp": "2023-04-17 22: ......

    uj5u.com 2023-04-20 08:24:54 more
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:24:03 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:23:11 more