会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132465个问题

导入数据失败,,,,,,,,,,,,,,,防火墙已关,solr已启动

  1. 网页访问

image.png


2.控制台错误提示

image.png3.mapper中书写无误

image.png

image.png

target中有新加入的内容

image.png

4.sql语句无误

image.png

 SELECT
item.id,
item.title,
item.sell_point,
item.price,
item.image,
cat.`name`,
idesc.item_desc
     FROM
        tb_item item
LEFT JOIN tb_item_cat cat ON item.cid = cat.id
LEFT JOIN tb_item_desc idesc ON item.id = idesc.item_id

5.pom文件中已经引入mapper

image.png


6.启动类中已经添加扫描

image.png

7.业务层代码 service

public interface SolrService {
    Result importAll();
    List<SolrDocument> selectByq(String q,  Long page, Integer pageSize );
}

实现类 serviceImpl

/**
 * 搜索服务 业务层
 */
@Service
public class SolrServiceImpl implements SolrService {
    @Autowired
    private SolrItemMapper solrItemMapper;
    @Autowired
    private SolrTemplate solrTemplate;
    @Value("${spring.data.solr.core}")
    private String bjsxt;
    /**
     *向索引库中导入数据
     * @return
     */
    @Override
    public Result importAll() {
        try {
            //查询数据
            List<SolrItem> list=this.solrItemMapper.getItemList();
            //将数据添加到索引库
            for (SolrItem item :
                    list) {
                //创建SolrInputDocument
                SolrInputDocument document=new SolrInputDocument();
                document.setField("id",item.getId());
                document.setField("item_title",item.getTitle());
                document.setField("item_sell_point",item.getSell_point());
                document.setField("item_price",item.getPrice());
                document.setField("item_image",item.getImage());
                document.setField("item_category_name",item.getName());
                document.setField("item_desc",item.getItem_desc());
                //写入数据库
                this.solrTemplate.saveDocument(this.bjsxt,document);

            }
            this.solrTemplate.commit(this.bjsxt);
            return  Result.ok();
        }catch (Exception e){
            e.printStackTrace();
        }
        return Result.error("导入失败");
    }

8.控制层

/**
 * 搜索服务 Controller
 */
@RestController
@RequestMapping("/search")
public class SolrController {
    @Autowired
    private SolrService solrService;
    /**
     * 向 Solr 索引库中导入数据
     */
    @RequestMapping("/importAll")
    public Result importAll(){
        return this.solrService.importAll();
    }

9.config

/**
 * SolrTemplate 配置类
 */
@Configuration
public class SolrConfig {
    @Autowired
    private SolrClient solrClient;

    @Bean
    public SolrTemplate getSolrTemplate(){

        return new SolrTemplate(solrClient);
    }
}

10.配置文件

image.png

JAVA 全系列/(旧的隐藏)第二十一阶段:百战商城项目(Spring Cloud最新架构)/百战商城项目 30887楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/容器(旧) 30890楼

主从库可以,但在用mycat连接mysql时,无法查询到表信息,报错:数据无法操作,百度上的各种方法都试过了,还是不行啊【schame.xml上的配置没问题,与视频中的区别就是 逻辑库也用了 demo1,表是user】

image.png


以下是日志信息:

2020-07-22 18:50:32.528  INFO [$_NIOREACTOR-0-RW] (io.mycat.backend.datasource.PhysicalDBPool.initSource(PhysicalDBPool.java:319)) - init result :finished 0 success 0 target count:0

2020-07-22 18:50:32.528 ERROR [$_NIOREACTOR-0-RW] (io.mycat.backend.datasource.PhysicalDBPool.init(PhysicalDBPool.java:279)) - #!MyCat#localhost1 init failure

2020-07-22 18:50:32.528  WARN [$_NIOREACTOR-0-RW] (io.mycat.server.NonBlockingSession.execute(NonBlockingSession.java:135)) - ServerConnection [id=5, schema=demo1, host=192.168.2.1, user=root,txIsolation=3, autocommit=true, schema=demo1]SHOW CREATE TABLE user, route={

   1 -> dn1{SHOW CREATE TABLE user}

}

java.lang.IllegalArgumentException: Invalid DataSource:0

at io.mycat.backend.datasource.PhysicalDBNode.getConnection(PhysicalDBNode.java:140) ~[Mycat-server-1.6-RELEASE.jar:?]

at io.mycat.backend.mysql.nio.handler.SingleNodeHandler.execute(SingleNodeHandler.java:182) ~[Mycat-server-1.6-RELEASE.jar:?]

at io.mycat.server.NonBlockingSession.execute(NonBlockingSession.java:132) ~[Mycat-server-1.6-RELEASE.jar:?]

at io.mycat.server.ServerConnection.routeEndExecuteSQL(ServerConnection.java:288) ~[Mycat-server-1.6-RELEASE.jar:?]

at io.mycat.server.ServerConnection.execute(ServerConnection.java:222) ~[Mycat-server-1.6-RELEASE.jar:?]

at io.mycat.server.handler.ShowHandler.handle(ShowHandler.java:60) ~[Mycat-server-1.6-RELEASE.jar:?]

at io.mycat.server.ServerQueryHandler.query(ServerQueryHandler.java:76) ~[Mycat-server-1.6-RELEASE.jar:?]

at io.mycat.net.FrontendConnection.query(FrontendConnection.java:317) ~[Mycat-server-1.6-RELEASE.jar:?]

at io.mycat.net.FrontendConnection.query(FrontendConnection.java:337) ~[Mycat-server-1.6-RELEASE.jar:?]

at io.mycat.net.handler.FrontendCommandHandler.handle(FrontendCommandHandler.java:71) ~[Mycat-server-1.6-RELEASE.jar:?]

at io.mycat.net.FrontendConnection.rawHandle(FrontendConnection.java:478) ~[Mycat-server-1.6-RELEASE.jar:?]

at io.mycat.net.FrontendConnection.handle(FrontendConnection.java:460) ~[Mycat-server-1.6-RELEASE.jar:?]

at io.mycat.net.AbstractConnection.onReadData(AbstractConnection.java:321) ~[Mycat-server-1.6-RELEASE.jar:?]

at io.mycat.net.NIOSocketWR.asynRead(NIOSocketWR.java:190) ~[Mycat-server-1.6-RELEASE.jar:?]

at io.mycat.net.AbstractConnection.asynRead(AbstractConnection.java:273) ~[Mycat-server-1.6-RELEASE.jar:?]

at io.mycat.net.NIOReactor$RW.run(NIOReactor.java:102) ~[Mycat-server-1.6-RELEASE.jar:?]

at java.lang.Thread.run(Thread.java:748) [?:1.8.0_221]

2020-07-22 18:50:33.180  INFO [$_NIOREACTOR-0-RW] (io.mycat.net.AbstractConnection.close(AbstractConnection.java:508)) - close connection,reason:quit cmd ,ServerConnection [id=7, schema=demo1, host=192.168.2.1, user=root,txIsolation=3, autocommit=true, schema=demo1]

2020-07-22 18:50:35.196  INFO [$_NIOConnector] (io.mycat.net.AbstractConnection.close(AbstractConnection.java:508)) - close connection,reason:java.net.NoRouteToHostException: 没有到主机的路由 ,MySQLConnection [id=0, lastTime=1595415032113, user=root, schema=demo1, old shema=demo1, borrowed=false, fromSlaveDB=false, threadId=0, charset=utf8, txIsolation=3, autocommit=true, attachment=null, respHandler=null, host=192.168.2.120, port=3306, statusSync=null, writeQueue=0, modifiedSQLExecuted=false]

2020-07-22 18:50:35.196  INFO [$_NIOConnector] (io.mycat.sqlengine.SQLJob.connectionError(SQLJob.java:114)) - can't get connection for sql :select user()

2020-07-22 18:50:35.196  INFO [$_NIOConnector] (io.mycat.backend.datasource.PhysicalDatasource.getConnection(PhysicalDatasource.java:413)) - no ilde connection in pool,create new connection for host1 of schema demo1

2020-07-22 18:50:35.197  INFO [$_NIOConnector] (io.mycat.net.AbstractConnection.close(AbstractConnection.java:508)) - close connection,reason:java.net.NoRouteToHostException: 没有到主机的路由 ,MySQLConnection [id=0, lastTime=1595415032113, user=root, schema=demo1, old shema=demo1, borrowed=false, fromSlaveDB=true, threadId=0, charset=utf8, txIsolation=3, autocommit=true, attachment=null, respHandler=null, host=192.168.2.121, port=3306, statusSync=null, writeQueue=0, modifiedSQLExecuted=false]

2020-07-22 18:50:35.197  INFO [$_NIOConnector] (io.mycat.sqlengine.SQLJob.connectionError(SQLJob.java:114)) - can't get connection for sql :select user()

2020-07-22 18:50:35.197  INFO [$_NIOConnector] (io.mycat.backend.datasource.PhysicalDatasource.getConnection(PhysicalDatasource.java:413)) - no ilde connection in pool,create new connection for host2 of schema demo1

[root@localhost logs]#


JAVA 全系列/第十三阶段:高性能数据处理、NoSQL、分库分表/MyCat 30891楼
JAVA 全系列/第一阶段:JAVA 快速入门/JAVA入门和背景知识 30895楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/容器(旧) 30896楼
JAVA 全系列/第一阶段:JAVA 快速入门/JAVA入门和背景知识 30897楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/容器(旧) 30898楼
Python 全系列/第一阶段:Python入门/编程基本概念 30899楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637