清除过滤器
文章
Michael Lei · 八月 9, 2022
在这篇文章中,你可以访问InterSystems开发者社区中与学习InterSystems IRIS最相关主题的文章库。找到按机器学习、嵌入式Python、JSON、API和REST应用、管理和配置InterSystems环境、Docker和云、VSCode、SQL、分析/BI、全局、安全、DevOps、互操作性、Native API排列的顶级发表的文章。快来享受学习的乐趣吧!
机器学习
机器学习是建立先进的数据分析和自动化人工活动的一种必要的技术,具有很好的效率。它可以创建认知模型,从现有的数据中学习,并根据其自我调整的算法进行预测、概率计算、分类、识别和 "非创造性 "的人类活动的自动化。
在所有情况下,InterSystems IRIS作为一个数据平台和环境来创建、执行、提供和使用这些机器学习模型。IRIS能够从SQL命令(IntegratedML)中使用ML,使用嵌入式Python和PMML(预测模型标记语言)来执行ML。你可以在以下文章中查看它的功能:
标题
描述
地址URL
一体化机器学习动手实验
一体化机器学习概览ML
https://cn.community.intersystems.com/node/517656
AI Robotization with InterSystems IRIS Data Platform(英文)
AI on IRIS productions
https://community.intersystems.com/post/ai-robotization-intersystems-iris-data-platform
利用IRIS 一体化机器学习IntegratedML来预测糖尿病的Web 应用
一体化机器学习示例
https://cn.community.intersystems.com/node/519381
Predict Maternal Health Risks(英文)
一体化机器学习示例
https://community.intersystems.com/post/predict-maternal-health-risks
Using Machine Learning to Organize the Community – 1(英文)
Using Python ML libraries
https://community.intersystems.com/post/using-machine-learning-organize-community-1
ObjectScript 语言
ObjectScript是InterSystems的官方编程语言。它简单、灵活,在创建后台、集成和分析应用程序方面非常强大。请查阅以下文章以了解更多信息:
标题
描述
地址URL
InterSystems ObjectScript 101++ (英文)
Video series to learn ObjectScript
https://community.intersystems.com/post/intersystems-objectscript-101-en
On $Sequence function(英文)
Create sequences of numbers
https://community.intersystems.com/post/sequence-function
Writing better-performing loops in Caché ObjectScript(英文)
Do loops
https://community.intersystems.com/post/writing-better-performing-loops-cach%C3%A9-objectscript
数据匿名化 IRIS-Disguise 工具介绍
学习如何定制化 ObjectScript 持久化类和属性
https://cn.community.intersystems.com/node/509271
ObjectScript 错误处理片段
异常处理
https://cn.community.intersystems.com/node/523756
Traditional Debugging in ObjectScript(英文)
Debug技巧
https://community.intersystems.com/post/traditional-debugging-objectscript
在Caché中使用正则表达式
使用正则表达式
https://cn.community.intersystems.com/node/487941
Robust Error Handling and Cleanup in ObjectScript(英文)
高质量代码
https://community.intersystems.com/post/robust-error-handling-and-cleanup-objectscript
SPOOL - the forgotten device(英文)
使用 Spool
https://community.intersystems.com/post/spool-forgotten-device
How we learned to stop worrying and love InterSystems Ensemble(英文)
Processing JSON on Productions
https://community.intersystems.com/post/how-we-learned-stop-worrying-and-love-intersystems-ensemble
一个更有用的 Object Dump
对象Dumping
https://cn.community.intersystems.com/node/523761
Logging using macros in InterSystems IRIS(英文)
Logging using macros
https://community.intersystems.com/post/logging-using-macros-intersystems-iris
SYSLOG - what it really is and what it means(英文)
Debug information on Syslog
https://community.intersystems.com/post/syslog-what-it-really-and-what-it-means
Tips for debugging with %Status(英文)
Debug using %Status
https://community.intersystems.com/post/tips-debugging-status
发挥 $Query 的最大作用
使用 $Query 查找数据
https://cn.community.intersystems.com/node/519806
Multidimensional Property Persistence - Part 1 (Classic) (英文)
Multidimensional persistent properties
https://community.intersystems.com/post/multidimensional-property-persistence-part-1-classic
The adopted Bitmap(英文)
Bitmap indexes
https://community.intersystems.com/post/adopted-bitmap
如何成为时间领主 - 诞生
日期和时间API
https://cn.community.intersystems.com/node/513356
Importance and Collection of Exact Version Information ($zv / $zversion)(英文)
Get IRIS version
https://community.intersystems.com/post/importance-and-collection-exact-version-information-zv-zversion
Date before Dec.1840 ? Negative $H(orolog) ?(英文)
日期为负
https://community.intersystems.com/post/date-dec1840-negative-horolog
Creating a Custom Index Type in Caché (英文)
创建定制索引
https://community.intersystems.com/post/creating-custom-index-type-cach%C3%A9
$LIST string format and %DynamicArray and %DynamicObject classes(英文)
Using $LIST, Dynamic Object, and Dynamic Arrays
https://community.intersystems.com/post/list-string-format-and-dynamicarray-and-dynamicobject-classes
SQL for ^ERROR Global(英文)
Use SQL to see Error content
https://community.intersystems.com/post/sql-error-global
Add a default setting value by code (英文)
设置默认值
https://community.intersystems.com/post/add-default-setting-value-code
Iterate over dynamic object(英文)
Use Iterate
https://community.intersystems.com/post/iterate-over-dynamic-object
列出类的所有属性 (我喜欢 ObjectScript 的原因)
ObjectScript 属性详解
https://cn.community.intersystems.com/node/512981
Try catch block I usually use in InterSystems ObjectScript(英文)
Try Catch 处理
https://community.intersystems.com/post/try-catch-block-i-usually-use-intersystems-objectscript
在ObjectScript中运行shell命令
Run shell commands
https://cn.community.intersystems.com/node/523766
嵌入式 Python
Python是世界上最流行和最常用的编程语言之一(https://www.tiobe.com/tiobe-index/)。InterSystems IRIS是一个对所有主要编程语言开放的数据平台。然而,说到Python,这种神奇的语言和它的库在IRIS中到处都可以使用:在类、SQL和集成/制作中。对于那些不知道或不想知道ObjectScript(InterSystems编程语言)的人来说,这是一个不错的选择。请看下面的文章,了解如何做到这一点:
标题
描述
URL地址
Let's fight against the machines(英文)
Build a tic tac toe game using Embedded Python
https://community.intersystems.com/post/lets-fight-against-machines
InterSystems IRIS 2021.2+ Python 代码样例 (Embedded嵌入式Python, Native 原生APIs 和 Notebooks)
使用 Python notebook 和 IRIS
https://cn.community.intersystems.com/node/508691
WebSocket Client with embedded Python(英文)
Custom Socket sample
https://community.intersystems.com/post/websocket-client-embedded-python
IRIS Python Native API in AWS Lambda (英文)
Python on AWS
https://community.intersystems.com/post/iris-python-native-api-aws-lambda
How I added ObjectScript to Jupyter Notebooks(英文)
IRIS on notebooks
https://community.intersystems.com/post/how-i-added-objectscript-jupyter-notebooks
Welcome Django(英文)
Create Python Django apps with IRIS as a database
https://community.intersystems.com/post/welcome-django
Geocoding with IRIS and Google Maps API (英文)
Using Geocoding python library
https://community.intersystems.com/post/geocoding-iris-and-google-maps-api
使用IRIS 和Python gTTS 实现文本转化声音的REST服务
使用 gTTS 的Python 案例
https://cn.community.intersystems.com/node/517551
使用 Python Flask Web 框架构建 IRIS 响应式仪表板
基于IRIS 的Flask web 应用
https://cn.community.intersystems.com/node/513086
JSON
JSON 是市场上最广泛使用的发送和接收数据的互操作性格式之一。InterSystems IRIS以多种方式支持这种格式。可以让你的本地数据库使用JSON(DocDB),序列化和反序列化对象,用JSON处理请求和响应,特别是来自REST服务的请求和响应。回顾以下文章:
标题
描述
URL地址
Introducing new JSON capabilities in Caché 2016.1 (英文)
Presenting ObjectScript JSON API
https://community.intersystems.com/post/introducing-new-json-capabilities-cach%C3%A9-20161
JSON Enhancements(英文)
JSON Adaptor API
https://community.intersystems.com/post/json-enhancements
API 和 REST 应用Applications
后台应用程序目前是以REST(Representational State Transfer)范式开发的,并以Web API的形式暴露。下面的文章将帮助你了解它是如何工作的:
标题
描述
URL地址
GraphQL for InterSystems Data Platforms (英文)
Create REST API with GraphQL style
https://community.intersystems.com/post/graphql-intersystems-data-platforms
Introducing InterSystems API Manager (英文)
API Management overview
https://community.intersystems.com/post/introducing-intersystems-api-manager
Advanced URL mapping for REST
Mapping routes to your APIs
https://community.intersystems.com/post/advanced-url-mapping-rest
AppS.REST - a new REST framework for InterSystems IRIS
Create REST apps easily
https://community.intersystems.com/post/appsrest-new-rest-framework-intersystems-iris
RESTForms - REST API for your classes
Create REST API for CRUD applications
https://community.intersystems.com/post/restforms-rest-api-your-classes
使用规范优先的方式开发REST API
以合同优先的方式开发API
https://cn.community.intersystems.com/node/484341
ObjectScript REST API Cookbook(英文)
REST API development tips
https://community.intersystems.com/post/objectscript-rest-api-cookbook
从持久类和序列类生成 Swagger 规范
Contract First Approach to develop APIs
https://cn.community.intersystems.com/node/484311
InterSystems IRIS REST Application Patterns
Create API REST using IRIS
https://community.intersystems.com/post/intersystems-iris-rest-application-patterns
Let's create an FHIR profile using SUSHI Part 1(英文)
Create custom FHIR profiles
https://community.intersystems.com/post/lets-create-fhir-profile-using-sushi-part-1
IAM (InterSystems API Manager), Zero to Hero(英文)
Manage your APIs with IAM
https://community.intersystems.com/post/iam-intersystems-api-manager-zero-hero
Using InterSystems API Management to Load Balance an API (英文)
Use APIM to do API load balance
https://community.intersystems.com/post/using-intersystems-api-management-load-balance-api
IAM实践指南——OAuth 2.0下的API保卫战(第一部分)
Secure your API using APIM
https://cn.community.intersystems.com/node/487141
Getting an Angular UI for your InterSystems IRIS application in 5 minutes (英文)
Full Stack app with IRIS and Angular
https://community.intersystems.com/post/getting-angular-ui-your-intersystems-iris-application-5-minutes
Upload into an InterSystems IRIS REST API (英文)
Save files using REST API
https://community.intersystems.com/post/upload-intersystems-iris-rest-api
管理和配置InterSystems环境
IRIS环境的良好管理和配置对用户使用的应用程序的性能、安全性、可用性和可靠性至关重要。这些文章可以给你很好的提示,告诉你如何做到这一点:
标题
描述
URL地址
InterSystems 数据平台的容量规划和性能系列文章
容量和性能规划提升
https://cn.community.intersystems.com/node/483921
Deploying Applications in InterSystems Cache with %Installer(英文)
Using %Installer to create namespaces, databases, and applications configuration
https://community.intersystems.com/post/deploying-applications-intersystems-cache-installer
Horizontal Scalability with InterSystems IRIS(英文)
Set IRIS instances for horizontal scalability
https://community.intersystems.com/post/horizontal-scalability-intersystems-iris
The InterSystems Iris Fhirserver running on a Raspberry Pi Raspberry running as a FHIRserver(英文)
Run IRIS inside Raspberry PI
https://community.intersystems.com/post/intersystems-iris-fhirserver-running-raspberry-pi-raspberry-running-fhirserver
Database Mirroring without a Virtual IP Address(英文)
Set mirrors using VIP
https://community.intersystems.com/post/database-mirroring-without-virtual-ip-address
Apache Web Gateway with Docker(英文)
Configure SSL and Web Gateway for web applications
https://community.intersystems.com/post/apache-web-gateway-docker
Work with SAML in IRIS(英文)
SAML to Web services
https://community.intersystems.com/post/work-saml-iris
掌握 %SYSTEM.Encryption 加密类
Encrypt and decrypt using IRIS
https://cn.community.intersystems.com/node/518191
Docker 和 Cloud
新的应用架构在容器Docker和云中工作,旨在实现弹性扩展,快速安装、配置和提供服务,并降低基础设施的复杂性和成本。学习这些文章,了解如何将IRIS带入云中:
题目
描述
URL地址
Highly available IRIS deployment on Kubernetes without mirroring(英文)
IRIS on cloud clusters with Kubernetes
https://community.intersystems.com/post/highly-available-iris-deployment-kubernetes-without-mirroring
面向 Amazon Web Services (AWS) 的 InterSystems IRIS 示例参考架构
基于AWS的IRIS
https://cn.community.intersystems.com/node/484351
面向 Microsoft Azure Resource Manager (ARM) 的 InterSystems 示例参考架构
基于Azure 资源管理器(ARM)架构的IRIS
https://cn.community.intersystems.com/node/484361
Dockerfile 和它的朋友们或者如何在 InterSystems IRIS 上运行和合作 ObjectScript 项目
Docker项目里的重要文件管理
https://cn.community.intersystems.com/node/484326
InterSystems IRIS Deployment Guide for AWS using CloudFormation template(英文)
IRIS on AWS using CloudFormation
https://community.intersystems.com/post/intersystems-iris-deployment%C2%A0guide-aws%C2%A0using-cloudformation-template
面向 Google Cloud Platform (GCP) 的 InterSystems IRIS 示例参考架构
IRIS on Google Cloud
https://cn.community.intersystems.com/node/484056
Using AWS Glue with InterSystems IRIS(英文)
Using IRIS and AWS Glue (AWS ETL tool)
https://community.intersystems.com/post/using-aws-glue-intersystems-iris
Amazon EKS, IRIS 高可用与备份
基于AWS的IRIS高可用
https://cn.community.intersystems.com/node/517536
Running InterSystems Reports in containers(英文)
IRIS reports on Docker
https://community.intersystems.com/post/running-intersystems-reports-containers
Running InterSystems IRIS in a FaaS mode with Kubeless(英文)
IRIS on Kubernetes
https://community.intersystems.com/post/running-intersystems-iris-faas-mode-kubeless
InterSystems Kubernetes Operator Deep Dive: Introduction to Kubernetes Operators(英文)
IRIS on Kubernetes
https://community.intersystems.com/post/intersystems-kubernetes-operator-deep-dive-introduction-kubernetes-operators
Scaling Cloud Hosts and Reconfiguring InterSystems IRIS(英文)
Scaling IRIS on AWS, Azure, or GCP
https://community.intersystems.com/post/scaling-cloud-hosts-and-reconfiguring-intersystems-iris
Deploying a Simple IRIS-Based Web Application Using Amazon EKS(英文)
IRIS on AWS
https://community.intersystems.com/post/deploying-simple-iris-based-web-application-using-amazon-eks
VSCode
VSCode是世界上最常用的开发IDE之一。IRIS完全支持这个IDE。请看以下文章:
标题
描述
URL地址
GitHub上的VSCode-ObjectScript
在网页版 Github VSCode上开发IRIS 应用
https://community.intersystems.com/post/vscode-objectscript-github
GitHub Codespaces with IRIS(英文)
Develop IRIS apps into Web Github
https://community.intersystems.com/post/github-codespaces-iris
VSCode Tips & Tricks - SOAP Wizard(英文)
Create shortcut option on VSCode
https://community.intersystems.com/post/vscode-tips-tricks-soap-wizard
Adding your own snippets to VS Code(英文)
Create snippets
https://community.intersystems.com/post/adding-your-own-snippets-vs-code
SQL
SQL是处理关系型数据库的最常用语言之一。这些文章展示了如何进行查询和数据持久性:
标题
描述
URL地址
Free Text Search: The Way To Search Your Text Fields That SQL Developers Are Hiding From You!*(英文)
Using Indexes to promote advanced search
https://community.intersystems.com/post/free-text-search-way-search-your-text-fields-sql-developers-are-hiding-you
改善日期范围查询的SQL性能
使用日期进行SQL查询
https://cn.community.intersystems.com/node/523636
Static WHERE Conditions(英文)
Where on Persistent Classes
https://community.intersystems.com/post/static-where-conditions
2021.2 SQL Feature Spotlight - Run Time Plan Choice(英文)
Select Runtime SQL Execution Plan
https://community.intersystems.com/post/20212-sql-feature-spotlight-run-time-plan-choice
New in 2020.1: the Universal Query Cache(英文)
SQL Cache
https://community.intersystems.com/post/new-20201-universal-query-cache
Materialized Views(英文)
Create views inside persistent classes
https://community.intersystems.com/post/materialized-views
SQL Debug 小技巧
Debug SQL commands
https://cn.community.intersystems.com/node/518701
Using ClassQueries() as Tables(英文)
Creating views
https://community.intersystems.com/post/using-classqueries-tables
M:N Relationship(英文)
Mapping N to N relationships
https://community.intersystems.com/post/mn-relationship
Reading AWS S3 data on COVID as SQL table in IRIS (英文)
Get CSV data from AWS S3 to IRIS table
https://community.intersystems.com/post/reading-aws-s3-data-covid-sql-table-iris
The One Query Performance Trick You NEED to Know? Tune Table! (英文)
SQL tunning
https://community.intersystems.com/post/one-query-performance-trick-you-need-know-tune-table
Data Storage - Information You Must Know to Make Good Decisions When Developing (英文)
Configure the data storage section on a persistent class to get more performance
https://community.intersystems.com/post/data-storage-information-you-must-know-make-good-decisions-when-developing
Improve SQL Performance for Date Queries, AGAIN! (英文)
Tunning SQL queries for dates
https://community.intersystems.com/post/improve-sql-performance-date-queries-again
Scrollable ResultSet Pagination Sample(英文)
Paginate SQL results (see comments too)
https://community.intersystems.com/post/scrollable-resultset-pagination-sample
第 1 天:使用 InterSystems Object 和 SQL 进行开发
Concepts about SQL into InterSystems IRIS
https://cn.community.intersystems.com/node/490806
DB Migration using SQLgateway(英文)
Migrate from PostgreSQL, MySQL, and other databases to IRIS
https://community.intersystems.com/post/db-migration-using-sqlgateway
Importing CSV into the Existing Table in InterSystems IRIS(英文)
Import CSV to SQL Table
https://community.intersystems.com/post/importing-csv-existing-table-intersystems-iris
访问IRIS数据平台的四种API方式
SQL API
https://cn.community.intersystems.com/node/493276
Indexing of non-atomic attributes(英文)
Create advanced index options
https://community.intersystems.com/post/indexing-non-atomic-attributes
Know Your Indices(英文)
Index creation fundamentals
https://community.intersystems.com/post/know-your-indices
Dynamic SQL to Dynamic Object(英文)
Use DynamicSQL
https://community.intersystems.com/post/dynamic-sql-dynamic-object
数据迁移工具 - 第一部分: 从 Postgres 到 IRIS
如何从其他数据库迁移到 IRIS 的系列文章
https://cn.community.intersystems.com/node/510831
BI与分析
BI和分析可以根据图形、仪表盘、摘要和详细表格中的数据分析,并根据分析员用户的导航和数据探索来做出决策。以下是如何使用IRIS建立分析应用的方法:
标题
描述
URL地址
InterSystems IRIS 上的 COVID-19 分析
分析全球疫情的仪表盘
https://community.intersystems.com/post/covid-19-analytics-intersystems-iris
DeepSee Troubleshooting Guide(英文)
Fix problems
https://community.intersystems.com/post/deepsee-troubleshooting-guide
AnalyzeThis – Quick start into InterSystems BI (英文)
Quick start into IRIS BI
https://community.intersystems.com/post/analyzethis-%E2%80%93-quick-start-intersystems-bi
Power BI Connector for InterSystems IRIS. Part I(英文)
Using IRIS data inside Power BI
https://community.intersystems.com/post/power-bi-connector-intersystems-iris-part-i
Creating Portlets in DeepSee(英文)
Analytics Portlets with IRIS BI
https://community.intersystems.com/post/creating-portlets-deepsee
Game Of Throne Analytics or How long is Arya's Stark List(英文)
Analytics sample
https://community.intersystems.com/post/game-throne-analytics-or-how-long-aryas-stark-list
DeepSee Web: InterSystems Analytics Visualization with AngularJS. Part 1(英文)
Web dashboards using Angular
https://community.intersystems.com/post/deepsee-web-intersystems-analytics-visualization-angularjs-part-1
Building Analytics Solution with IRIS(英文)
Present main options to do analytics with IRIS
https://community.intersystems.com/post/building-analytics-solution-iris
Globals
Globals 是IRIS中灵活存储和检索数据的关键机制,无论是SQL、类、JSON文档、BI立方体,还是其他自定义格式。在下面的文章中可以看到如何做到这一点:
题目
描述
URL地址
The Art of Mapping Globals to Classes 1 of 3(英文)
Mapping globals to SQL tables and Objects
https://community.intersystems.com/post/art-mapping-globals-classes-1-3
Globals 是管理数据的魔剑 : 第一部分
Globals 基础
https://cn.community.intersystems.com/node/520821
GlobalToJSON-embeddedPython-pure(英文)
Export globals to JSON
https://community.intersystems.com/post/globaltojson-embeddedpython-pure
Transactions in Global InterSystems IRIS(英文)
Manage transactions on Globals persistence
https://community.intersystems.com/post/transactions-global-intersystems-iris
Store Mindmaps using Globals(英文)
Using globals to persist mindmap data
https://community.intersystems.com/post/store-mindmaps-using-globals
安全
确保任何应用程序的安全是至关重要的。安全性与访问和授权管理有关,跟踪和审计交易,对存储和传输的内容进行加密,以及设置正确的配置参数以确保合理资源的保护。阅读这些文章,了解更多关于如何建立安全的信息:
标题
Description
URL
InterSystems IRIS 开放授权框架 (OAuth 2.0) 实现 – 第 1 部分
使用 OAuth
https://cn.community.intersystems.com/node/484366
Debugging Web(英文)
Debugging CSP and REST apps
https://community.intersystems.com/post/debugging-web
Class Queries in InterSystems IRIS(英文)
Defining SQL Queries inside Persistent classes
https://community.intersystems.com/post/class-queries-intersystems-iris
在TLS/SSL中使用操作系统的证书库
利用 OS 证书实现 SSL
https://cn.community.intersystems.com/node/518186
一致性检查_ 加速还是减速
保证一致性
https://cn.community.intersystems.com/node/485041
跟踪数据更改 - 审计日志 - 上篇
保存审计数据
https://cn.community.intersystems.com/node/486831
Running the Management Portal (Private Web Server) Over TLS/SSL/HTTPS(英文)
Configure SSL to IRIS Web Server
https://community.intersystems.com/post/running-management-portal-private-web-server-over-tlssslhttps
OAuth Authorization and InterSystems IRIS: Taming Trust Protocols(英文)
Using OAuth
https://community.intersystems.com/post/oauth-authorization-and-intersystems-iris-taming-trust-protocols
Using Oauth2 with SOAP (Web)Services(英文)
Oauth setting for SOAP services
https://community.intersystems.com/post/using-oauth2-soap-webservices
DeepSee: Setting up security - Part 1 of 5(英文)
Security on IRIS BI
https://community.intersystems.com/post/deepsee-setting-security-part-1-5
Changes to the security level of the system(英文)
Security by default
https://community.intersystems.com/post/changes-security-level-system
DevOps
DevOps是一种采用实践和工具的方式,使源代码从开发(Dev)到生产运行(Ops)的快速和高质量的过渡成为可能。请看如何在IRIS中做到这一点。
题目
描述
URL地址
Continuous Delivery of your InterSystems solution using GitLab - Part I: Git(英文)
Continuous delivery with GitLab
https://community.intersystems.com/post/continuous-delivery-your-intersystems-solution-using-gitlab-part-i-git
Introducing InterSystems ObjectScript Package Manager(英文)
Use ZPM to configure and install third-party packages inside your application
https://community.intersystems.com/post/introducing-intersystems-objectscript-package-manager
ZPMshow - a helper for tired fingers(英文)
How to use ZPM – IRIS Package Manager
https://community.intersystems.com/post/zpmshow-helper-tired-fingers
如何以自动化方式/编程方式创建一个镜像环境
自动化创建镜像
https://cn.community.intersystems.com/node/512986
ObjectScript包管理器中的单元测试和测试覆盖率
为ObjectScript 代码质量创建单元测试
https://cn.community.intersystems.com/node/486826
使用Doker和配置文件模版来部署Sharded 集群
使用 CPF文件自动化配置
https://cn.community.intersystems.com/node/518356
Caché ObjectScript 快速参考
ObjectScript reference pdf document
https://cn.community.intersystems.com/node/523791
The Anatomy of ZPM Module: Packaging Your InterSystems Solution(英文)
Use ZPM to automate deployment
https://community.intersystems.com/post/anatomy-zpm-module-packaging-your-intersystems-solution
在IRIS容器里添加VSCode
在容器中嵌入 VSCode
https://cn.community.intersystems.com/node/516431
如何以编程/自动化方式为InterSystems IRIS创建新的数据库、命名空间和Web应用程序
自动化创建数据库和命名空间
https://cn.community.intersystems.com/node/523796
Unit Tests: Quality of your ObjectScript Code(英文)
Quality Assurance with Unit Tests
https://community.intersystems.com/post/unit-tests-quality-your-objectscript-code
一些有用的 InterSystems 开发者社区 Docker Images镜像
Docker社区镜像
https://cn.community.intersystems.com/node/515076
互操作性
IRIS有一个强大的数据和应用互操作性总线。通过以下文章了解如何使用它.
题目
描述
URL
Sending Alerts from Ensemble via Telegram(英文)
Production to send data to telegram
https://community.intersystems.com/post/sending-alerts-ensemble-telegram
[首次使用InterSystems IRIS]-让我们来使用互操作性!
创建BS, BO, BP和productions
https://cn.community.intersystems.com/node/513971
使用嵌入式Python实现InterSystems IRIS 互操作性
使用Python创建BS, BO, BP和production
https://cn.community.intersystems.com/node/512176
Ensemble / Interoperability Training Course(英文)
Great sample to learn how to create productions
https://community.intersystems.com/post/ensemble-interoperability-training-course
几个程序化实现互操作性的示例
使用 Python 或 ObjectScript 程序化Productions
https://cn.community.intersystems.com/node/516221
Listing files in folder(英文)
List files in a folder
https://community.intersystems.com/post/listing-files-folder
Containerising .Net/Java Gateways (or Kafka Integration Demo)(英文)
Kafka support using Java or .Net Native API
https://community.intersystems.com/post/containerising-netjava-gateways-or-kafka-integration-demo
Implementing IRIS Integrations with .NET or Java using PEX(英文)
Using PEX to create productions using Java or .Net
https://community.intersystems.com/post/implementing-iris-integrations-net-or-java-using-pex
Migrate from Java Business Host to PEX(英文)
Using PEX
https://community.intersystems.com/post/migrate-java-business-host-pex
Using Tesseract OCR and Java Gateway(英文)
Using Java PEX
https://community.intersystems.com/post/using-tesseract-ocr-and-java-gateway
Creating a PEX Business Operation(英文)
Create Java PEX Business Operation
https://community.intersystems.com/post/creating-pex-business-operation
在IRIS中联合运用OCR与NLP技术
Java PEX 样例
https://cn.community.intersystems.com/node/494206
Creating a custom interoperability business service using an HTTP Adapter(英文)
Creating Business Services
https://community.intersystems.com/post/creating-custom-interoperability-business-service-using-http-adapter
原生 API
IRIS对市场上最常用的一些编程语言(Java、Javascript/NodeJS、.Net、C++和Python)的工作持开放态度。为了做到这一点,我们为这些语言中的每一种使用了本地API。请看这些文章:
题目
描述
URL地址
WebSocket Client JS with IRIS Native API as Docker Micro Server(英文)
Using IRIS and NodeJS to do a WebSocket
https://community.intersystems.com/post/websocket-client-js-iris-native-api-docker-micro-server
IRIS Native API for ObjectScript(英文)
Using Native APIs
https://community.intersystems.com/post/iris-native-api-objectscript
Using ZPM for Node.js(英文)
Using ZPM on Node.js projects
https://community.intersystems.com/post/using-zpm-nodejs
Creating a PDF from a Text file(英文)
Java Native API for generating PDF
https://community.intersystems.com/post/creating-pdf-text-file
How to Start Development with InterSystems IRIS in Less Than a Minute(英文)
Start to develop using IRIS
https://community.intersystems.com/post/how-start-development-intersystems-iris-less-minute
Making a blog using Python + IRIS Globals(英文)
A blog on using Python native API
https://community.intersystems.com/post/making-blog-using-python-iris-globals
希望我们翻译哪片文章,欢迎给我们留言!
文章
Jingwei Wang · 九月 16, 2022
连接前准备:
Java 开发环境
InterSystems JDBC 驱动
Connection String
步骤:
配置 Classpath :指向InterSystems JDBC 驱动 - intersystems-jdbc-3.0.0.0.jar
Connection String,其中import com.intersystems.jdbc*;用来导入驱动,User是命名空间名称。
import com.intersystems.jdbc*;
import java.sql.Connection;
public class JDBCConnection{
public static void main (String[] args) throws Exception {
String dbUrl = "jdbc:IRIS://127.0.0.1:1972/User"; //replace
String user = "SQLAdmin";
String pass = "deployment-password";
IRISDataSource ds = new IRISDataSource();
ds.setURL(dbUrl);
ds.setUser(user);
ds.setPassword(pass);
Connection dbconnection = ds.getConnection();
System.out.println("Connected to InterSystems IRIS via JDBC.");
}
}
公告
Claire Zheng · 九月 19, 2022
开发者社区的同学们,大家好!
在 之前的公告 中,我们向大家介绍了InterSystems官方反馈门户 InterSystems Ideas! 今天想给大家介绍更多,尤其是涉及到的主题。
你可以按以下主题类别提交你的想法:
💡 InterSystems Products(InterSystems产品) 在这里,您可以在这里发布与我们产品发展相关的创意和想法:
InterSystems IRIS数据平台
InterSystems IRIS for Health(医疗版)数据平台
InterSystems HealthShare
InterSystems TrakCare
💡 InterSystems Services(InterSystems服务) 您可以在这里发表如何使我们的服务变得更好的想法:
Developer Community (开发者社区)
Open Exchange app gallery(Open Exchange应用库)
Global Masters gamification platform(Global Masters游戏平台)
Partner Directory(供应商目录)
Documentation(文档)
Certification(认证)
Learning (学习)
以及InterSystems Ideas Portal
还有一个主题类别是 "Other(其他)" ,如果您的创意和想法与上述两类不直接相关,可以放在这个类别下。
选择好类别(Category)后,您也可以自由添加合适的关键字/标签:
如果您认为还有哪些类别和关键字值得被添加到这里,欢迎随时与我们分享!
点击一下,来 InterSystems Ideas portal 提出你的意见和建议吧✌️
文章
Michael Lei · 九月 12, 2022
针对InterSystems开发者社区的分析。使用InterSystems IRIS BI (DeepSee)、Power BI和Logi Report Designer制作的项目,可视化并分析InterSystems 开发者社区上的成员、文章、问题、答案、观点和其他内容和活动。
你可以看到自己的活动、文章和问题。跟踪你的贡献如何改变开发者社区。
使用IRIS BI、Adaptive Analytics、InterSystems Reports、Tableau和Power BI分析关于你和你朋友的统计数据。
该项目包含预配置的IRIS和Atscale在Docker容器中的部署以及BI系统的项目文件。
更多细节信息请见相应应用的README。
这个项目也支持在线部署,你可以在这里查看。
公告
Claire Zheng · 一月 7, 2021
大家好!InterSystems Global Masters 倡导中心与开发者社区紧密联系并不是秘密。 为开发者社区做出任何贡献都会带来 Global Masters 积分。 所以, 我们准备了一份关于如何在 Global Masters 以最佳方式获得积分的简短指南。
如何在 GLOBAL MASTERS 获得积分
在开发者社区上发布英文帖子
100
第一次在社区评论
回答一个问题 / 发表一个评论(英文)
300
30
第 1 个被标记为“已接受”的回答
1000
之后的每一个“已接收”回答
150
第5/10/25/50个“已接收”回答
4000/8000/20000/40000
翻译一篇文章
50
在 DC 上问第1/5/10/25/50个问题
500/2000 /5000 /15000/30000
在 DC 上发布第1/5/10/25/50个帖子
1500/7500/15000/40000/75000
在 Open Exchange 发布一个应用程序
800
对每一个ZPM应用积分奖励
400
在Open Exchange发布第1/5/10/25个应用程序
1000/10000/25000/75000
帖子浏览量达到750+/2000+/5000+/15000+
600/2500/7000/20000
在开发者社区阅读一篇帖子
10
看一个视频
20
通过社交媒体分享一次(帖子/视频)
40
发布的第1/2/3/4/5 篇带“最佳实践”标签的文章
1000/3000/7000/10000/15000
在Open Exchange上您的应用第50/100/250/500/1000次下载
2500/5000/7500/12500/25000
对 InterSystems / InterSystems 产品作一次评述
2 000-3 000
邀请成员加入开发者社区
600
为您的OEX应用创建一个video
3000
*仅计算在 Global Masters 倡导中心注册后发布的帖子。
完成挑战,获得徽章并升级:Insider > Advocate > Specialist > Expert > VIP。 您的级别越高,可获得的奖励越有趣!
欢迎点击查看更多有关 Global Masters 的其他信息:
如何加入 InterSystems Global Masters
Global Masters 徽章说明
Global Masters 级别说明
Global Masters 计划的变更
如果您尚未加入 InterSystems Global Masters 倡导中心,现在就开始行动吧! 欢迎在本帖评论中提出您的问题。 欢迎大家多参与Global Master,多积分,多贡献,提高等级,赢取礼品!
@Young Zheng @An Xingqi @jinhui hu @wenyang zhang @guoguo wang @shikai ren @chaolong huang @yabin duan @鹏飞 楚 @智辉 李 @SHAN HU @Wendy Wu
@Hao Wang @Z C @Zhaoying Li @Neal Wu @liu yaquan @qu qu @wang wei @guo meiya@yajing xu @yue li @权权 苏 @xiaohu xiong @yadong zhao @Yi Han @Wen Zhou @jie zhang @张 恒 @guo wenheng @Jing Li @迪 文
文章
Li Yan · 一月 18, 2021
企业需要快速有效地扩展和管理其全球计算基础设施,同时优化和管理资本成本及支出。 Amazon Web Services (AWS) 和 Elastic Compute Cloud (EC2) 计算和存储服务提供高度稳健的全球化的计算基础设施,可满足最苛刻的基于 Caché 的应用程序的需求。Amazon EC2 基础设施使各公司能够迅速预置计算能力和/或快速灵活地将其现有内部基础架构扩展到云端。 AWS 针对安全、网络、计算和存储提供了一套丰富的服务和强大的企业级机制。
AWS 的核心是 Amazon EC2。 它是支持各种操作系统和机器配置(例如 CPU、RAM、网络)的云计算基础设施。 AWS 提供预先配置的虚拟机 (VM) 映像(称为 Amazon 系统映像或 AMI),客户操作系统包括各种 Linux® 和 Windows 发行版及版本。 可以将其它软件用作 AWS 中运行的虚拟化实例的基础。 您可以将这些 AMI 用作实例化以及安装或配置其他软件、数据等的起点,以创建特定于应用程序或工作负载的 AMI。
与任何平台或部署模式一样,必须留心以确保考虑到应用程序环境的各个方面,例如性能、可用性、操作和管理程序。
本文将详细介绍以下每个方面。
网络设置和配置。 此部分介绍基于 Caché 的应用程序在 AWS 中的网络设置,包括为参考架构内不同层级和角色的逻辑服务器组提供支持的子网。
服务器设置和配置。 此部分介绍为每一层设计各种服务器时涉及的服务和资源。 还包括用于跨可用区实现高可用性的架构。
安全。 此部分讨论 AWS 中的安全机制,包括如何配置实例和网络安全以实现对整体解决方案以及层和实例之间的授权访问。
部署和管理。此部分提供有关打包、部署、监控和管理的详细信息。
架构和部署方案
本文提供了几个在 AWS 内实现的参考架构,作为提供基于 InterSystems 技术(包括 Caché、Ensemble、HealthShare、TrakCare)以及相关嵌入式技术(如 DeepSee、iKnow、CSP、Zen 和 Zen Mojo)的高性能和高可用性应用程序的示例。
为了了解如何在 AWS 上托管 Caché 及相关组件,我们先来回顾一下典型 Caché 部署的架构和组件,并探讨一些常见的方案和拓扑。
Caché架构回顾
InterSystems 数据平台不断发展,提供先进的数据库管理系统和快速的应用程序开发环境,以在处理和分析复杂数据模型以及开发 Web 和移动应用程序方面实现突破。
这是新一代的数据库技术,提供多种数据访问模式。 数据只在单个集成数据字典中描述一次,并且可以通过对象访问、高性能 SQL 和强大的多维存取即时进行访问 – 所有这些方式可以同时访问相同数据。
图 1 说明了可用的 Caché 高级架构组件层和服务。 这些通用层也适用于 InterSystems TrakCare 和 HealthShare 产品。
图 1:高级组件层
常见部署方案
部署有许多可能的组合,但本文将介绍两种方案:混合模型和完整的云托管模型。
混合模型
在此方案中,公司希望在需要时将企业内部资源和 AWS EC2 资源都用于灾难恢复、内部维护应急、重新平台化计划或短期/长期扩容。 此模型可以为内部故障转移镜像成员集群提供业务连续性和灾难恢复的高可用性。
在该方案中,此模型的连接依赖于内部部署和 AWS 可用区之间的 VPN 隧道,将 AWS 资源作为企业数据中心的扩展。 还有其他连接方法,例如 _AWS Direct Connect_。 但是,这不是本文涵盖的内容。 有关 AWS Direct Connect 的更多详细信息,可以在here找到。
有关设置此 Amazon Virtual Private Cloud (VPC) 示例以支持内部数据中心灾难恢复的详细信息可以在here找到。
图 2:使用 AWS VPC 提供内部灾难恢复的混合模型
上面的示例展示了一个故障转移镜像对通过与 AWS VPC 的 VPN 连接在内部数据中心的运行。 所示的 VPC 在给定 AWS 区域的双可用区中提供了多个子网。 有两个灾难恢复 (DR) 异步镜像成员 (每个可用区有一个) 提供弹性。
云托管模型
在此方案中,基于 Caché 的应用程序(包括数据层和表示层)完全放在 AWS 云中,使用了单个 AWS 区域内的多个可用区。 可以使用相同的 VPN 隧道 AWS Direct Connect, 甚至纯互联网连接模型。
图 3:支持完整生产工作负载的云托管模型
图 3 中的示例说明了在 VPC 中支持整个应用程序生产部署的部署模型。 此模型利用双可用区,在可用区之间同步故障转移镜像,同时将负载均衡 Web 服务器和相关应用程序服务器作为 ECP 客户端。 每个层都隔离在一个单独的安全组中,以进行网络安全控制。 IP 地址和端口范围仅根据应用程序的需要开放。
存储和计算资源
存储
有多种类型的存储选项可供选择。 就本参考架构而言,将针对几种可能的用例讨论 Amazon Elastic Block Store (Amazon EBS) 和 (也称为临时驱动器)卷。 各种存储选项的更多详细信息可以在 here 和 here 找到。
Elastic Block Storage (EBS)
EBS 提供了可与 Amazon EC2 实例(虚拟机)配合使用的持久块级存储,在 Linux 或 Windows 中可以将其格式化并挂载为传统文件系统,最重要的是,这些卷是非实例存储,独立于单个 Amazon EC2 实例的运行寿命而持续存在,这对于数据库系统非常重要。
此外,Amazon EBS 还提供了创建卷的时间点快照的功能,这些快照会持久保存在 Amazon S3 中。 这些快照可以用作新的 Amazon EBS 卷的起点,并保护数据以实现长期耐久性。 同一快照可用于实例化任意数量的卷。 这些快照可以跨 AWS 区域复制,因此可以更容易地利用多个 AWS 区域进行地理扩张、数据中心迁移和灾难恢复。 Amazon EBS 卷的大小范围为 1 GB 到 16 TB,以 1 GB 为增量进行分配。
Amazon EBS 内有三种不同的类型:磁介质卷、通用型 (SSD) 和预置 IOPS (SSD)。 以下各小节提供了每种类型的简要介绍。
磁介质卷
磁介质卷为具有中等或突发 I/O 要求的应用程序提供经济高效的存储。 磁介质卷设计为平均每秒提供约 100 次输入/输出操作 (IOPS),最大突发能力为数百 IOPS。 磁介质卷也非常适合用作启动卷,其突发能力提供了快速的实例启动时间。
通用型 (SSD)
通用型 (SSD) 卷提供具有成本效益的存储,是各种工作负载的理想选择。 这些卷的延迟只有个位数毫秒,能够长时间突发至 3,000 IOPS,基准性能为 3 IOPS/GB,最高可达 10,000 IOPS (3,334 GB)。 通用型 (SSD) 卷的大小范围为 1 GB 到 16 TB。
预置 IOPS (SSD)
预置 IOPS (SSD) 卷设计用于为 I/O 密集型工作负载(例如对存储性能和随机访问 I/O 吞吐量的一致性敏感的数据库工作负载)提供可预测的高性能。 在创建卷时指定 IOPS 速率,然后 Amazon EBS 在给定一年的 99.9% 的时间内提供 10% 内的预置 IOPS 性能。 预置 IOPS (SSD) 卷的大小可以为 4 GB 到 16 TB,每个卷最多可预置 20,000 IOPS。 预置的 IOPS 与请求的卷大小之比最大为 30;例如,IOPS 为 3,000 的卷必须至少为 100 GB 大小。 预置 IOPS (SSD) 卷对每个预置的 IOPS 的吞吐量限制为 256 KB,最高 320 MB/秒(1,280 IOPS)。
本文讨论的架构使用 EBS 卷,因为这些卷更适合需要可预测的低延迟每秒输入/输出操作 (IOPS) 和吞吐量的生产工作负载。 选择特定的虚拟机类型时必须小心,因为并非所有 EC2 实例类型都可以访问 EBS 存储。
注意: 由于 Amazon EBS 卷是网络附加设备,Amazon EC2 实例执行的其他网络 I/O 以及共享网络上的总负载可能会影响单个 Amazon EBS 卷的性能。 为了让 Amazon EC2 实例充分利用 Amazon EBS 卷上的预置 IOPS,可以将选定的 Amazon EC2 实例类型作为 Amazon EBS 优化的实例启动。
有关 EBS 卷的详细信息,可以在here 找到。
EC2 实例存储(临时驱动器)
EC2 实例存储由托管您的正在运行的 Amazon EC2 实例的同一台物理服务器上的磁盘存储的预配置和预附加块组成。 提供的磁盘存储量因 Amazon EC2 实例类型而异。 在提供实例存储的 Amazon EC2 实例系列中,较大的实例往往提供更多更大的实例存储量。
存储优化 (I2) 和密集存储 (D2) 的 Amazon EC2 实例系列提供针对特定用例的专用实例存储。 例如,I2 实例提供了非常快的 SSD 实例存储,能够支持超过 365,000 的随机读取 IOPS 和 315,000 的写入 IOPS,并提供具有成本吸引力的定价模型。
与 EBS 卷不同,该存储不是永久性的,只能用于实例的生命周期,不能分离或附加到其他实例。 实例存储用于临时存储不断变化的信息。 在 InterSystems 技术和产品领域中,诸如将 Ensemble 或 Health Connect 用作企业服务总线 (ESB) 的项目、使用企业缓存协议 (ECP) 的应用程序服务器或将 Web 服务器与 CSP 网关一起使用,对于这种类型的存储和存储优化的实例类型,以及使用预置和自动化工具来提高有效性和支持弹性的操作来说,都是很好的用例。
有关实例存储卷的详细信息,可以在here 找到。
计算
EC2 实例
有多种实例类型可供使用,它们针对各种用例进行了优化。 实例类型包括 CPU、内存、存储和网络容量的不同组合,从而实现无数种组合来合理调整您的应用程序的资源要求。
就本文档而言,将参考_通用 M4_ Amazon EC2 实例类型作为优化环境大小的方法,这些实例提供 EBS 卷的功能和优化。 根据您的应用程序的容量要求和定价模型,还可能有替代方案。
M4 实例是最新一代的_通用_实例。 此系列提供了计算、内存和网络资源的平衡配置,对于许多应用程序来说是很好的选择。 容量范围为 2 到 64 个虚拟 CPU 和 8 到 256GB 的内存,以及相应的专用 EBS 带宽。
除了各个实例类型,还有分层的分类,例如专用主机、Spot 实例、预留实例和专用实例,每个类别的定价、性能和隔离都不同。
在 here 确认当前可用实例的可用性和详细信息。
可用性和操作
Web/App 服务器负载均衡
您的基于 Caché 的应用程序可能需要外部和内部负载均衡的 Web 服务器。 外部负载均衡器用于通过互联网或 WAN(VPN 或 Direct Connect)进行的访问,内部负载均衡器可用于内部流量。 AWS Elastic Load Balancing 提供两种类型的负载均衡器 – 应用程序负载均衡器和传统负载均衡器。
传统负载均衡器
传统负载均衡器根据应用程序或网络信息对流量进行路由,是在多个需要高可用性、自动扩展和强大安全性的 EC2 实例之间实现简单的流量负载均衡的理想选择。 具体的详细信息和功能可在here 找到。
应用负载均衡器
应用程序负载均衡器是 Elastic Load Balancing 服务的负载均衡选项,该服务在应用程序层运行,允许您根据一个或多个 Amazon EC2 实例上运行的多个服务或容器中的内容定义路由规则。 此外,还支持 WebSockets 和 HTTP/2。 具体的详细信息和功能可在here找到。
示例
在以下示例中,定义了一组三个 Web 服务器,每个服务器都在一个单独的可用区,以提供最高级别的可用性。 必须为 Web 服务器负载均衡器配置粘性会话 ,才能支持使用 cookie 将用户会话固定到特定 EC2 实例的功能。 当用户继续访问您的应用程序时,流量将路由到相同实例。
图 4 给出了 AWS 中的传统负载均衡器的一个简单示例。
图 4:传统负载均衡器示例
数据库镜像
在 AWS 上部署基于 Caché 的应用程序时,如果要为 Caché 数据库服务器提供高可用性,则需要在给定的主 AWS 区域使用同步数据库镜像来提供高可用性,还可能需要使用异步数据库镜像将数据复制到辅助 AWS 区域中的热备份以实现灾难恢复,具体取决于正常运行时间服务水平协议要求。
数据库镜像是两个数据库系统的逻辑分组,也就是所说的故障转移成员,它们在物理上是仅通过网络连接的独立系统。 在这两个系统之间进行仲裁后,镜像会自动将其中一个系统指定为主系统; 另一个成员自动成为备份系统。 外部客户端工作站或其他计算机通过镜像虚拟 IP (VIP) 连接到镜像,该虚拟 IP 在镜像配置期间指定。 镜像 VIP 会自动绑定到主镜像系统上的接口。
注意: 在 AWS 中,无法以传统方式配置镜像 VIP,因此设计了替代解决方案。 不过,镜像可跨子网获得支持。
目前在 AWS 中部署数据库镜像的建议是,在跨越三个不同可用区的同一个 VPC 中配置三个实例(主要、备份、仲裁器)。 这可以确保在任何给定时间,AWS 都将保证可以从外部连接其中的至少两个虚拟机,SLA 达到 99.95%。 这样可以为数据库数据本身提供充分的隔离和冗余。 有关 AWS EC2 服务水平协议的详细信息,可在here 找到。
故障切换成员之间的网络延迟没有硬性上限。延迟增加所产生的影响因应用程序而异。如果故障转移成员之间的往返时间与磁盘写入服务时间相似,则预计不会产生影响。 但是,当应用程序必须等待数据变为持久保存(有时称为日志同步)时,响应时间可能是一个问题。 有关数据库镜像和网络延迟的详细信息,可在here 找到。
虚拟 IP 地址和自动故障转移
大多数 IaaS 云提供商缺乏提供虚拟 IP (VIP) 地址的能力,这种地址通常用在数据库故障转移设计中。 为解决这一问题,Caché、Ensemble 和 HealthShare 中增强了几种最常用的连接方法,尤其是 ECP 客户端和 CSP 网关,从而不再依赖 VIP 功能使它们实现镜像感知。
xDBC、直接 TCP/IP 套接字等连接方法或其他直接连接协议仍需要使用 VIP。 为解决这些问题,InterSystems 数据库镜像技术通过使用 API 与 AWS Elastic Load Balancer (ELB) 进行交互以实现类似 VIP 的功能,使得在 AWS 中为这些连接方法提供自动故障转移成为可能,从而在 AWS 中提供完整而强大的高可用性设计。
此外,AWS 最近推出了一种新类型的 ELB,称为应用程序负载均衡器。 这种类型的负载均衡器在第 7 层运行,支持基于内容的路由,并支持在容器中运行的应用程序。 基于内容的路由对于使用分区数据或数据分片部署的大数据类型项目尤其有用。
与虚拟 IP 一样,这是网络配置的突然变化,不涉及任何应用逻辑,不会向已连接到发生故障的主镜像成员的现有客户端发出正在进行故障转移的通知。 根据故障的性质,这些连接终止的原因可能是故障本身、应用程序超时或错误、新的主镜像实例强制旧的主镜像实例停机,或者客户端使用的 TCP 保持连接定时器过期。
结果,用户可能必须重新连接并登录。 您的应用程序的行为将决定此行为。 有关各种类型的可用 ELB 的详细信息,可在here找到。
AWS EC2 实例对 AWS Elastic Load Balancer 方法的调用
在此模型中,ELB 可以定义一个包含故障转移镜像成员和潜在 DR 异步镜像成员的服务器池,其中只有一个活动条目是当前主镜像成员,或者只定义一个具有单个活动镜像成员条目的服务器池。
图 5:与 Elastic Load Balancer 交互的 API 方法(内部)
当某个镜像成员成为主镜像成员时,会从您的 EC2 实例向 AWS ELB 发出一个 API 调用,以调整/指示新主镜像成员的 ELB。
图 6:使用负载均衡器的 API 故障转移到镜像成员B
如果主镜像成员和备份镜像成员都变得不可用,同一模型也适用于升级 DR 异步镜像成员。
图 7:使用负载均衡器的 API 将 DR 异步镜像成员升级为主镜像成员
按照标准推荐的 DR 过程,上面的图 6 中的 DR 成员升级需要人为决策,因为异步复制可能会造成数据丢失。 不过,一旦执行该操作,就不再需要对 ELB 执行管理操作。 在升级期间调用 API 后,将自动路由流量。
API 详细信息
这个用于调用 AWS 负载均衡器资源的 API 在 ^ZMIRROR 例程中专门定义为以下过程调用的一部分:
$$CheckBecomePrimaryOK^ZMIRROR()
在此过程内,插入您选择的要从 AWS ELB REST API、命令行界面等使用的任何 API 逻辑或方法。 与 ELB 进行交互的一种有效且安全的方法是使用 AWS Identity and Access Management (IAM) 角色,这样不必为 EC2 实例分配长期凭据。 IAM 角色提供了 Caché 可以用来与 AWS ELB 进行交互的临时权限。 有关使用分配给 EC2 实例的 IAM 角色的详细信息,可在 here 找到。
AWS Elastic Load Balancer 轮询方法
2017.1 提供了一种使用 CSP 网关的mirror_status.cxw 页的轮询方法,可以将其用作 ELB 监控每个已添加到 ELB 服务器池的镜像成员运行状况的轮询方法。只有主镜像会响应“SUCCESS”,因而网络流量只定向到活动的主镜像成员。
此方法不需要向 ^ZMIRROR 添加任何逻辑。 请注意,大多数负载均衡网络设备对运行状态检查的频率有限制。 通常,最高频率不少于5秒,这通常是可接受的,可支持大多数正常运行时间服务水平协议。
一个对以下资源的 HTTP 请求将测试本地缓存配置的镜像成员状态。
/csp/bin/mirror_status.cxw
对于所有其他情况,这些镜像状态请求的路径应解析到适当的缓存服务器和命名空间,它们与用于请求实际 CSP 页的缓存服务器和命名空间使用相同的分层机制。
示例:在 /csp/user/ 路径中测试服务于应用程序的配置的镜像状态:
/csp/user/mirror_status.cxw
注意:调用镜像状态检查不消耗 CSP 许可证。
根据目标实例是否为活动的主要成员,网关将返回以下 CSP 响应之一:
** Success (Is the Primary Member)
===============================
HTTP/1.1 200 OK
Content-Type: text/plain
Connection: close
Content-Length: 7
SUCCESS
** Failure (Is not the Primary Member)
===============================
HTTP/1.1 503 Service Unavailable
Content-Type: text/plain
Connection: close
Content-Length: 6
FAILED
** Failure (The Cache Server does not support the Mirror_Status.cxw request)
===============================
HTTP/1.1 500 Internal Server Error
Content-Type: text/plain
Connection: close
Content-Length: 6
FAILED
下图说明了各种使用轮询方法的方案。
图 8:轮询所有镜像成员
如上面的图 8 所示,所有镜像成员都在运行,只有主镜像成员向负载均衡器返回“SUCCESS”,因此网络流量将只定向到该镜像成员。
图 9:使用轮询故障转移到镜像成员 B
上图演示了将 DR 异步镜像成员升级到负载均衡池中的过程,这通常假定同一台负载均衡网络设备为所有镜像成员提供服务(本文稍后将介绍按地理位置划分的方案)。
按照标准推荐的 DR 过程,DR 成员升级需要人为决策,因为异步复制可能会造成数据丢失。 不过,一旦执行该操作,就不再需要对 ELB 执行管理操作。 它会自动发现新的主镜像成员。
图 10:使用轮询对 DR 异步镜像成员进行故障转移和升级
备份和还原
备份操作有多个选项。 对于 InterSystems 产品的 AWS 部署,可以使用以下三个选项。 前两个选项包括一个快照类型过程,该过程在创建快照前会暂停将数据库写入磁盘,然后在快照成功建立后恢复更新。 执行以下高级步骤使用任一快照方法创建干净备份:
通过数据库冻结 API 调用暂停对数据库的写入。
创建操作系统和数据磁盘的快照。
通过数据库解锁API 调用恢复 Caché 写入。
将设施存档备份到备份位置。
可以定期添加完整性检查等其他步骤,以确保备份干净一致。 决定使用哪个选项取决于组织的运营要求和策略。 InterSystems 可与您详细讨论各种选项。
EBS 快照
EBS 快照是在高度可用和成本较低的 Amazon S3 存储上创建时间点快照的非常快速且有效的方法。 EBS 快照连同 InterSystems 外部冻结和解锁API 功能,可以实现真正的 24x7 弹性运行,并确保干净的定期备份。 使用 AWS 提供的服务(如 Amazon CloudWatch Events)或市场上的第三方解决方案(如 Cloud Ranger 或 N2W Software Cloud Protection Manager 等等),有许多选项可以使该过程自动化。
此外,还可以使用 AWS 直接 API 调用,以编程方式创建您自己的自定义备份解决方案。 有关如何利用 API 的详细信息,请参见here 和here.
注意:InterSystems 不为上述任何第三方产品背书或明确进行验证。 测试和验证取决于客户.
逻辑卷管理器快照
或者,通过在虚拟机自身内部署单独的备份代理,并利用文件级备份与 Linux 逻辑卷管理器 (LVM) 快照或 Windows 卷影复制服务 (VSS) 相结合,可以使用市场上的许多第三方备份工具。
此模型的主要优点之一是能够对基于 Windows 或 Linux 的实例进行文件级还原。 该解决方案有几点需要注意,由于 AWS 和大多数其他 IaaS 云提供商不提供磁带介质,因此所有备份存储库都基于磁盘进行短期归档,而且能够利用 Amazon S3 低成本存储并最终使用 Amazon Glacier 实现长期保留 (LTR)。 如果使用此方法,强烈建议使用支持去重技术的备份产品,以最有效地利用基于磁盘的备份存储库。
这些具有云支持的备份产品的示例包括但不限于:Commvault、EMC Networker、HPE Data Protector 和 Veritas Netbackup。
注意:InterSystems 不为上述任何第三方产品背书或明确进行验证。 测试和验证取决于客户.
Caché 在线备份
对于小型部署,内置 Caché 在线备份工具也是一个可行选项。 该 InterSystems 数据库在线备份实用工具通过捕获数据库中的所有块来备份数据库文件中的数据,然后将输出写入顺序文件。 这种专有的备份机制旨在使生产系统的用户不停机。
在 AWS 中,在线备份完成后,必须将备份输出文件和系统使用的所有其他文件复制到用作文件共享的 EC2 (CIFS/NFS)。 该过程需要在虚拟机中编写脚本并执行。
在线备份是入门级方法,适合于希望实施低成本备份解决方案的小型站点。 但是,随着数据库的增大,建议将使用快照技术的外部备份作为最佳做法,其优势包括:备份外部文件、更快的恢复时间,以及企业范围的数据视图和管理工具。
灾难恢复
在 AWS 上部署基于 Caché 的应用程序时,建议将 DR 资源(包括网络、服务器和存储)放在不同的 AWS 区域中,或者至少放在单独的可用区中。指定的 DR AWS 区域所需的容量取决于您组织的需求。 在大多数情况下,以 DR 模式运行时需要 100% 的生产能力,但作为一个弹性模型,可以先预置较少的能力,直到需要更多能力。 较少的能力可以体现为较少的 Web 和应用程序服务器,甚至可能使用较小的 EC2 实例类型作为数据库服务器,升级后,EBS 卷将附加到较大的 EC2 实例类型。
异步数据库镜像用于连续复制到 DR AWS 区域的 EC2 实例。 镜像使用数据库事务日志以对主系统性能影响最小的方式通过 TCP/IP 网络复制更新。 强烈建议对这些 DR 异步镜像成员配置日志文件压缩和加密。
公共互联网上所有希望访问应用程序的外部客户端都将通过作为附加 DNS 服务的 Amazon Route53 进行路由。Amazon Route53 用作将流量定向至当前活动数据中心的交换机。 Amazon Route53 执行三种主要功能:
域注册 –允许您注册 example.com 之类的域名。
域名系统 (DNS) 服务 – Amazon Route53 将类似 www.example.com 的友好域名转换为 192.0.2.1 之类的 IP 地址。 Amazon Route53 使用全球权威 DNS 服务器网络来响应 DNS 查询,从而降低延迟。
运行状况检查–Amazon Route53 通过互联网向您的应用程序发送自动请求,以验证其是否可达、可用和正常运行。
这些功能的详细信息可在 here找到。
就本文档而言,将讨论 DNS 故障转移和 Route53 运行状况检查。 运行状况检查监控和 DNS 故障转移的详细信息可在 here 和here找到。
Route53 的工作方式是向每个端点发出常规请求,然后验证响应。 如果某个端点未能提供有效响应, 它将不再包含在 DNS 响应中,而是返回一个替代的可用端点。 这样,用户流量就会从发生故障的端点转向可用的端点。
使用上述方法,将只允许流量转向特定区域和特定镜像成员。 这是由端点定义控制的,它是本文先前讨论过的 mirror_status.cxw 页,由 InterSystems CSP 网关提供。 只有主镜像成员会在运行状况检查中报告 HTTP 200 来表示“SUCCESS”。
下图演示了高级别的故障转移路由策略。 此方法和其他策略的详细信息可在here找到。
图 11:Amazon Route53 故障转移例程策略
在任何给定时间,只有一个区域会根据端点监控进行在线报告。 这样可以确保流量在给定时间只流向一个区域。 区域之间的故障转移无需增加步骤,因为端点监控将检测到指定的主 AWS 区域中的应用程序已关闭,并且该应用程序此时在次要 AWS 区域中处于活动状态。 这是因为 DR 异步镜像成员已被手动升级为主镜像成员,随后允许 CSP 网关将 HTTP 200 报告给 Elastic Load Balancer 端点监控。
上述解决方案有很多替代方案,可以根据您组织的运营要求和服务水平协议进行自定义。
监控
Amazon CloudWatch 可用于为您的所有 AWS 云资源和应用程序提供监控服务。 Amazon CloudWatch 可用于收集和跟踪指标,收集和监控日志文件,设置警报,并自动对 AWS 资源的变化做出反应。 Amazon CloudWatch 可以监控 AWS 资源,如 Amazon EC2 实例,以及您的应用程序和服务生成的自定义指标,还有您的应用程序生成的任何日志文件。 您可以使用 Amazon CloudWatch 获得系统范围内的资源利用率、应用程序性能和运行状况的可见性。 详细信息可在here找到。
自动预置
目前,市场上有许多工具,包括 Terraform、Cloud Forms、Open Stack 和 Amazon 自己的 CloudFormation。 使用这些工具并与其他工具(如 Chef、Puppet、Ansible 等)相结合,可以提供完整的基础设施即代码,来支持 DevOps 或简单地以完全自动化的方式引导您的应用程序。 Amazon CloudFormation 的详细信息可在here找到。
网络连接
根据您的应用程序的连接要求,有多种连接模型可用:使用互联网、VPN 或使用 Amazon Direct Connect 的专用链接。 选择方法取决于应用程序和用户需求。 三种方法的带宽使用情况各不相同,最好通过 AWS 代表或 Amazon 管理控制台确认给定区域的可用连接选项。
安全
当决定通过任何公共 IaaS 云提供商部署应用程序时,都需要谨慎。 应遵循您组织的标准安全策略或专门针对云制定的新策略,以保持您组织的安全合规性。 当组织的数据存储在其国家/地区之外,并受数据所在国家/地区的法律约束时,相关的数据主权也是您必须了解的。 现在,云部署增加了数据在客户数据中心和物理安全控制之外的风险。 强烈建议对静态数据(数据库和日志)和动态数据(网络通信)使用 InterSystems 数据库和日志加密,分别使用 AES 和 SSL/TLS 加密。
与所有加密密钥管理一样,您需要按照您组织的策略记录并遵循正确的程序,以确保数据安全,防止不必要的数据访问或安全漏洞。
Amazon 提供了大量文档和示例,为基于 Caché 的应用程序提供高度安全的运行环境。 请务必查看here 关于 Identity Access Management (IAM) 的各种讨论主题。
架构图示例
下图说明了典型的 Caché 安装,其以数据库镜像(同步故障转移和 DR 异步)、使用 ECP 的应用程序服务器,以及多个负载均衡 Web 服务器的方式提供高可用性。
TrakCare 示例
下图说明了典型的 TrakCare 部署,其中包含多个负载均衡 Web 服务器,两个作为 ECP 客户端的 EPS 打印服务器,以及数据库镜像配置。 虚拟 IP 地址仅用于与 ECP 或 CSP 网关不关联的连接。 ECP 客户端和 CSP 网关可感知镜像,不需要 VIP。
如果您正在使用 Direct Connect,则可为灾难恢复方案启用包括多线路和多区域访问在内的多个选项。 与电信提供商合作以了解他们支持的高可用性和灾难恢复方案至关重要。
下面的示例参考架构图包括活动或主要区域中的高可用性,以及在主要 AWS 区域不可用时到其他 AWS 区域的灾难恢复。 而且在此示例中,数据库镜像包含 TrakCare DB、TrakCare Analytics 和 Integration 命名空间,全部在单个镜像集内。
图 12:TrakCare AWS 参考架构图 – 物理架构
此外,下图显示了更有逻辑的架构图,其中包含所安装的相关高级软件产品及功能用途。
图 13:TrakCare AWS 参考架构图 – 逻辑架构
HealthShare 示例
下图显示了一个典型的 HealthShare 部署,其中含有多个负载均衡 Web 服务器,以及多个 HealthShare 产品,包括 Information Exchange、Patient Index、Personal Community、Health Insight 和 Health Connect。 这些产品中的每一个都包含一个数据库镜像对,以在多个可用区内提供高可用性。 虚拟 IP 地址仅用于与 ECP 或 CSP 网关不关联的连接。 用于 HealthShare 产品之间的 Web 服务通信的 CSP 网关可感知镜像,不需要 VIP。
下面的示例参考架构图包括活动或主要区域中的高可用性,以及在主要区域不可用时到其他 AWS 区域的灾难恢复。
图 14:HealthShare AWS 参考架构图 – 物理架构
此外,下图显示了更有逻辑的架构图,其中包含所安装的相关高级软件产品、连接要求和方法,以及相应的功能用途。
Figure-15: HealthShare AWS 参考架构图 – 逻辑架构
文章
Claire Zheng · 二月 1, 2021
大家好!
如您所知,我们发布了 InterSystems Open Exchange — 面向 InterSystems 数据平台上的解决方案和工具的市场!
但是如何在 OE 上发布应用程序?
在开始前,我先回答几个基本问题。
谁可以发布?
基本上,每个人都可以。 您可以使用您的 InterSystems 开发者社区帐户或 WRC 帐户登录 Open Exchange。
什么是应用程序?
Open Exchange 应用程序是使用任何 InterSystems 数据平台产品(Caché、Ensemble、HealthShare、InterSystems IRIS 或 InterSystems IRIS for Health)开发的解决方案、工具、互操作性适配器或接口。
或者该工具或解决方案应该有助于 InterSystems 数据平台上的开发、测试、部署或管理解决方案。
什么是 Open Exchange 的应用程序?
实际上,它是应用程序条目的名称、描述和链接集:下载页面、文档、代码仓库(如果有)、许可证等。
让我用我个人的示例来介绍这个过程。
将应用程序提交到 Open Exchange
为了说明这个过程,我在 ObjectScript for InterSystems IRIS 上开发了一个出色的应用程序,并希望将其与开发者社区分享:Ideal ObjectScript。
它演示了 ObjectScript 编码准则在各种 ObjectScript 用例中的理想用法。
有一些必需字段需要出现在每个 Open Exchange 应用程序上。
1. 名称 - 对于 Open Exchange 唯一的应用程序名称
2. 描述 - 应用程序的描述。 该字段支持 markdown。
3. 产品 URL - 应用程序下载页面的链接。
4. 许可证 - 显示应用程序许可证的页面的链接。
5. InterSystems 数据平台 - 应用程序面向的 InterSystems 数据平台集。
其余所有字段都是可选的。
那么,让我们来提交我的应用程序。
名称: Ideal ObjectScript
描述: Ideal ObjectScript 演示了 InterSystems ObjectScript 编码准则在各种 ObjectScript 用例中的理想用法。
产品URL: https://github.com/evshvarov/ideal_objectscript/releases/tag/1.0 - 应用程序的 Github 发行版部分中 1.0 版本的链接。
许可证URL: https://github.com/evshvarov/ideal_objectscript/blob/1.0/LICENSE - 应用程序的 LICENSE 文件的链接。
InterSystems数据平台: 该应用程序支持 InterSystems IRIS、Caché 和 Ensemble - 这是我自己测试过该应用程序的 InterSystems 产品列表。
这样,我们就可以提交应用程序了。
应用程序版本
在点击“Send For Approval”(发送以供批准)后,您需要提供应用程序的版本和版本说明。 我们使用 Semver 进行版本控制。 版本说明将发布在 Open Exchange 新闻、DC 社交媒体和应用程序的版本历史部分中。
在该应用程序进入批准工作流程后(结果是审批通过并自动在 OpEx 上发布,或者提供一些关于如何更正应用程序描述和链接的建议)。
输入
其他参数
图片 URL
在您的应用程序的图片图标上放置一个 URL,以使其显示在图块上。 您可以省略此参数,将显示标准 OpEx 图标。
Github URL
如果您的应用程序有 Github 仓库,则放置它的链接。 我们在 Open Exchange 上与 Github 进行了整合,因此,如果您引入指向应用程序的 Github 仓库的链接,Open Exchange 将自动显示来自 Github 的描述(Readme.md 中列出的所有内容)。 例如, 查看 Ideal ObjectScript 页面如何 显示在Open Exchange上。
社区文章URL
当然,您可以在开发者社区上用精彩的文章介绍您的应用程序,所以在这里放上文章的 URL!
如您所见,这个过程非常简单! 期待在 Open Exchange 上看到您的 InterSystems 数据平台应用程序!
敬请期待!
文章
jieliang liu · 三月 1, 2021
大数据的 5 个 V 与 InterSystems IRIS
参见下表:
Velocity(速度):水平和垂直节点扩展传递出的弹性速度 实现者:分布式内存缓存、分布式处理、分片和多模型架构 https://www.intersystems.com/isc-resources/wp-content/uploads/sites/24/ESG_Technical_Review-InterSystems-IRIS.pdf 和 https://learning.intersystems.com/course/view.php?id=1254&ssoPass=1
Value(价值):Analytics 和 AI产生的指数数据价值实现:BI、NLP、ML、AutoML 和多模型架构 https://docs.intersystems.com/irislatest/csp/docbook/Doc.View.cls?KEY=SETAnalytics 和 https://docs.intersystems.com/irislatest/csp/docbook/DocBook.UI.Page.cls?KEY=GIML_AUTOML
Veracity(真实性):在公司层面统一的单一真实数据源--实现者:连接器、数据总线、数据集成的 BPL 以及 API 管理 https://docs.intersystems.com/irislatest/csp/docbook/Doc.View.cls?KEY=PAGE_interoperability 和 https://docs.intersystems.com/irislatest/csp/docbook/DocBook.UI.Page.cls?KEY=AFL_iam
Volume(容量):多个性能出色的 TB/PB 级数据存储库 实现者:分布式内存缓存、分布式处理、分片和多模型架构 https://www.intersystems.com/isc-resources/wp-content/uploads/sites/24/ESG_Technical_Review-InterSystems-IRIS.pdf 和 https://learning.intersystems.com/course/view.php?id=1254&ssoPass=1
Variety(多样性):同一位置多种数据格式(XML、JSON、SQL、对象)实现者:Repositório e Arquitetura Multimodelohttps://docs.intersystems.com/irislatest/csp/docbook/DocBook.UI.Page.cls?KEY=PAGE_multimodel
文章
Qiao Peng · 三月 5, 2021
大家好!
InterSystems IRIS 有一个名为 **Interoperability**(互操作性)的菜单。
它提供了轻松创建系统集成(适配器、记录映射、BPM、数据转换等)的机制,因此可以轻松连接不同的系统。
数据中继过程中可以包括各种操作,例如:为了连接没有正常连接的系统,可以根据目标系统的规范来接收(或发送)数据。 此外,在发送数据之前,可以从其他系统获取和添加信息。 还可以从数据库(IRIS 等)获取和更新信息。
在本系列文章中,我们将讨论以下主题,同时查看 示例代码 以帮助您了解工作原理以及在系统中集成互操作性时需要进行哪种开发。
* 工作原理
* 什么是Production
* 消息
* 组件创建
* 业务操作
* 业务流程
* 业务服务
首先,我介绍一下我们将在本系列文章中使用的案例研究。
> 某公司运营着一个购物网站,他们正在更改产品信息的显示顺序以配合季节变化。但是,有些商品无论季节如何都能卖得很好,而有些商品在意料之外的时间卖出,这不符合当前的显示顺序更改规则,因此,我们研究了按照当天的温度而不是季节来更改显示顺序的可能性。 调查购买产品时的温度变得非常必要。由于可以使用外部 Web API 来查询天气信息,因此我们计划收集购买时的天气信息,并将其记录在后面的审核数据库中。
案例非常简单,但您需要使用“外部 Web API”来收集信息,并且需要将获得的信息和购买信息结合起来记录在数据库中。
具体说明将在相关文章中讨论(不包括网站的创建)。 请移步观看!
至于我们这次使用的“外部 Web API”,我们使用的是 OpenWeather的 当前天气数据.
(如果您想要尝试一下,您需要注册一个帐户并获得 API ID).
以下是一个 REST 客户端发出的 GET 请求的结果(我们将以在 Interoperability 中实现的机制来运行此流程)。

HTTP 响应的 JSON 如下所示:
```json
{
"coord": {
"lon": 135.5022,
"lat": 34.6937
},
"weather": [
{
"id": 803,
"main": "Clouds",
"description": "broken clouds",
"icon": "04d"
}
],
"base": "stations",
"main": {
"temp": 17.05,
"feels_like": 13.33,
"temp_min": 16,
"temp_max": 18,
"pressure": 1017,
"humidity": 55
},
"visibility": 10000,
"wind": {
"speed": 4.63,
"deg": 70
},
"clouds": {
"all": 75
},
"dt": 1611635756,
"sys": {
"type": 1,
"id": 8032,
"country": "JP",
"sunrise": 1611612020,
"sunset": 1611649221
},
"timezone": 32400,
"id": 1853909,
"name": "Osaka",
"cod": 200
}
```
在 下一篇文章中,我们将讨论如何使用 Interoperability 菜单进行系统集成。
[OpenWeather]: https://openweathermap.org/
文章
Qiao Peng · 三月 28, 2021
如果您正打算学习FHIR、或者正在基于FHIR开发,最佳的学习和开发环境需要一个完备的FHIR 服务器,帮助您理解FHIR标准和调试FHIR应用。使用InterSystems IRIS医疗行业版可以快速配置出FHIR服务器和FHIR资源仓库。这篇文章介绍如何在5分钟内在InterSystems IRIS医疗行业版上配置FHIR服务器和FHIR资源仓库;同时对初学者介绍FHIR测试数据生成与加载的方法,和基本的FHIR REST API操作。
软件准备
1. InterSystems IRIS医疗行业版
您可以使用已有的2020.1及以上的InterSystems IRIS医疗行业版。如果您还没有,那么就在社区里下载一个最新的、免费的社区版吧。
2. 测试用的FHIR数据
如果您正在做FHIR开发,应该有很多FHIR测试数据。如果您正在学习FHIR,那么Synthea是一个不错的FHIR测试数据生成器选项。
3. REST测试工具
您或许已经有趁手的REST测试工具了。如果还没有,POSTMAN是个不错的选择。我的例子里用到的就是POSTMAN。
FHIR服务器配置
1. 安装InterSystems IRIS医疗行业版或社区版
如果您还没有安装过InterSystems IRIS医疗行业版或社区版,社区里有很多很好的介绍文章。
2. 配置FHIR服务器
2.1 创建一个FHIR 服务器命名空间
在InterSystems IRIS医疗行业版或社区版上,需要创建一个FHIR服务器命名空间。HS.HC.Util.Installer类的方法InstallFoundation可以创建这样的命名空间,例如,我们创建一个名为FHIRSERVER的命名空间:
HSLIB>D ##class(HS.HC.Util.Installer).InstallFoundation("FHIRSERVER")
2.2 为这个命名空间配置FHIR访问端点 (FHIR endpoint)
进入管理门户,切换到FHIRSERVER命名空间,然后Health > FHIR Configuration, 然后点击“Server Configuration”。这里会列出已有的FHIR服务器的访问端点,并可以配置新的端点。
这里点击+号,在弹出的配置页面中进行设置,其配置项是:
选中支持的FHIR版本 (Select a metadata set): 如果要支持最新的FHIR版本4,选中HL7V40,就是FHIR R4;
选中交换策略 (Select an interaction strategy): 默认情况下只会有一个选项 - HS.FHIRServer.Storage.Json.InteractionsStrategy,它会将InterSystems IRIS同时配置为FHIR资源仓库。
设置FHIR服务器REST服务端点 (Enter a name(URL)): 例如/csp/healthshare/fhirserver/fhir/r4
然后点击Finish,让它完成后台的配置,这可能会花费1分钟。
2.3 修改这个FHIR服务端点
因为我们是想利用它来学习和测试FHIR,所以我们先跳过访问认证部分。在端点列表中选中刚才创建的/csp/healthshare/fhirserver/fhir/r4,滚动到最下方,找到Edit按钮,并选中“Debugging”下的“Allow Unauthenticated Access”,让FHIR服务器接受匿名访问。然后点击Update进行更新。
如果您按上述步骤执行完成,并且没有错误,那么FHIR服务器和FHIR资源仓库已经就绪了。看看表,您用了多久完成FHIR服务器的创建。
下面测试一下FHIR服务器是否工作正常。
测试FHIR服务器
即便您还没有任何FHIR测试数据,也可以先看看这个FHIR服务器的能力声明。
通过POSTMAN,使用GET方法,进行REST调用:http://localhost:52776/csp/healthshare/fhirserver/fhir/r4/metadata。这里localhost:52776是我的测试InterSystems IRIS的服务器地址和Web服务端口号,您换成自己的就行。如果您不知道,那么用您访问InterSystems IRIS管理门户的地址和端口号。
因为我们在上一步配置时,允许匿名访问REST API,所以POSTMAN无需设置任何登陆账户,非常方便测试。正常情况下,您应该看到和我一样的结果:
您的FHIR服务器已经正常工作了,如果还没有测试数据,是时候加载一些FHIR数据进来了。
产生FHIR数据
如果您有自己的FHIR测试数据,请跳过此步,查看“加载FHIR数据”。
如果您还没有自己的FHIR数据,试试Synthea,它能方便的产生大量FHIR测试数据。Synthea有清晰的文档,告诉我们如何产生测试数据。(注:如果您是FHIR初学者,建议先少量创建FHIR测试数据文件,例如先创建5个)
通常它会产生3类JSON文件:
医院信息:hospitalInformation******.json, 每批次只会产生一个医院信息文件。
医生信息:practitionerInformation******.json, 每批次只会产生一个医生信息文件。
患者信息:<患者姓名>******.json, 每批次会根据设置产生一个或多个患者信息文件。
这些FHIR文件都是Bundle资源,Bundle里面会有很多FHIR资源数据。其中医院信息文件和医生信息文件的Bundle类型为batch,而患者信息的Bundle是transaction。
而Synthea产生的患者信息Bundle中的资源使用literal reference来引用医院/地点和医生信息,但它产生的literal reference信息不完整,例如:
"serviceProvider": {
"reference": "Organization?identifier=https://github.com/synthetichealth/synthea|731e0f3a-075d-37ab-9ba7-fbf1ab2f45e9",
"display": "THE GENERAL HOSPITAL CORPORATION"
}
需要将reference改为完整的地址,例如:
"serviceProvider": {
"reference": "http://localhost:52776/csp/healthshare/fhirserver/fhir/r4/Organization?identifier=https://github.com/synthetichealth/synthea|731e0f3a-075d-37ab-9ba7-fbf1ab2f45e9",
"display": "THE GENERAL HOSPITAL CORPORATION"
}
也就是增加FHIR服务器的端点。
需要替换/补齐的引用分别是:Location、Organization和Practitioner。
您可以通过文本编辑器进行全局替换,将FHIR服务器的端点信息补充到reference里。如果您产生了很多FHIR数据文件,当然可以用您熟悉的语言写几行代码做这个补充替换。
这里我也附上使用IRIS的Object Script做补充替换的代码示例,它会对指定目录下的所有json文件进行扫描和补充替换,供您参考:
Class Demo.FHIRTools Extends %RegisteredObject
{
/// 修正FHIR文件的引用
/// pFilePath为FHIR json文件目录
/// pFHIREndpoint为FHIR REST的服务端点
ClassMethod CorrectSyntheaFiles(
pFilePath As %String = "C:\Temp\Synthea\output\fhir",
pFHIREndpoint As %String = "http://localhost:52776/csp/healthshare/fhirserver/fhir/r4") As %Status
{
Set tSC = $$$OK
// 遍历目录下的json文件
Set tSM = ##class(%SQL.Statement).%New()
Set tSC = tSM.%PrepareClassQuery("%File", "FileSet")
If $$$ISERR(tSC)
{
Do $system.OBJ.DisplayError(tSC)
Return tSC
}
Set tRS = tSM.%Execute(pFilePath, "*.json", "Name")
While tRS.%Next()
{
// 创建临时文件
Set tFileName = tRS.%Get("Name"),tTempFileName=$Replace(tFileName,".json","temp.json")
Set tFile=##class(%Stream.FileCharacter).%New()
Set tTempFile = ##class(%Stream.FileCharacter).%New()
Set tSC=tTempFile.LinkToFile(tTempFileName)
Set tSC=tFile.LinkToFile(tFileName)
// 从源文件逐行读取,替换后写入临时文件
While 'tFile.AtEnd
{
Set tLine=tFile.ReadLine()
// 执行替换
For tKeyword="Location?identifier=","Organization?identifier=","Practitioner?identifier="
{
Set tLine = $Replace(tLine,tKeyword,pFHIREndpoint_"/"_tKeyword)
}
Set tSC = tTempFile.WriteLine(tLine)
}
Do tTempFile.%Save()
Do tFile.%Close(), tTempFile.%Close()
Kill tFile,tTempFile
// 删除源文件,并将临时文件改名为源文件名
Set tSC = ##class(%File).Delete(tFileName,.tRtn)
Set tSC = ##class(%File).Rename(tTempFileName, tFileName, .tRtn)
}
Return tSC
}
}
加载FHIR数据
当然可以通过FHIR REST API来加载数据,不过,InterSystems IRIS提供了后台的API,可以快速加载特定目录下的大量的FHIR数据文件。
这里我们用后台API:HS.FHIRServer.Tools.DataLoader的SubmitResourceFiles方法进行大量FHIR文件加载:
FHIRSERVER>Set sc=##class(HS.FHIRServer.Tools.DataLoader).SubmitResourceFiles("C:\Temp\Synthea\upload","FHIRSERVER","/csp/healthshare/fhirserver/fhir/r4")
其中第一个入参是需要加载的文件目录;第二个参数是加载的FHIR服务器类型,这里用FHIRSERVER;第三个参数是FHIR REST服务端点。
如果您是通过Synthea产生的测试FHIR JSON文件,那么应该先加载 医院信息文件(hospitalInformation******.json)和医生信息文件(practitionerInformation******.json),以确保患者数据加载时,Location、Organization和Practitioner的引用能正确关联到FHIR资源仓库中已保存的对应资源上。
注意:2020.* 版本中有一个bug,需要将医院信息文件(hospitalInformation******.json)和医生信息文件(practitionerInformation******.json)里的"type": "batch"改为"type": "transaction"。这个bug在2021.1版本中已经得到修复,我已经验证过,但如果您在使用2020的版本,请记得提前修改。
加载完医院信息文件(hospitalInformation******.json)和医生信息文件(practitionerInformation******.json)后,再执行相同的方法加载所有患者数据json文件。
使用FHIR 服务器
有了测试数据,现在您可以使用FHIR服务器进行学习或开发测试了。使用POSTMAN,您可以调用FHIR服务器的REST API,查询、更改、提交FHIR资源数据。
如果您是初学者,对FHIR的REST API不熟悉,建议您从FHIR Cheat Sheet开始,它是一个FHIR标准的汇总单页,里面告诉大家如何使用REST API进行操作。
例如:
1. 查询已经加载到FHIR资源仓库中的患者:
使用GET 方法调用REST:
http://localhost:52776/csp/healthshare/fhirserver/fhir/r4/Patient
2. 使用查询参数,查询名为Pedro316的患者:
使用GET 方法调用REST:
http://localhost:52776/csp/healthshare/fhirserver/fhir/r4/Patient?given=Pedro316
或使用POST 方法调用REST:
http://localhost:52776/csp/healthshare/fhirserver/fhir/r4/Patient/_search?given=Pedro316
3. 更复杂的查询参数用例,查询拥有观察项目编码为8302-2(体重)的患者:
使用GET 方法调用REST:
http://localhost:52776/csp/healthshare/fhirserver/fhir/r4/Patient?_has:Observation:patient:code=8302-2
4. 使用operation: $everything 来获取特定患者的所有相关FHIR资源(示例是id为95的患者):使用GET 方法调用REST:
http://localhost:52776/csp/healthshare/fhirserver/fhir/r4/Patient/95/$everything
5. 加载FHIR Bundle资源:
使用POST 方法调用REST:
http://localhost:52776/csp/healthshare/fhirserver/fhir/r4/
,并在Body中直接贴入FHIR资源数据到raw,或选择FHIR资源数据文件到binary。
注意:如果您是想让FHIR服务器解析Bundle中的FHIR资源,应该用http://localhost:52776/csp/healthshare/fhirserver/fhir/r4/,而不是http://localhost:52776/csp/healthshare/fhirserver/fhir/r4/Bundle。后者把POST的FHIR数据按Bundle进行处理,并不会解析其中包含的FHIR资源内容并逐一保存!
注意:记得根据FHIR数据的格式设置Content-Type为application/json+fhir 或 application/xml+fhir,然后将数据贴在Body里:
好了,开启您的FHIR之旅吧 :)
后续我还会更新InterSystems IRIS医疗版作为FHIR服务器和FHIR资源仓库的更多内容,欢迎关注。
公告
Nicky Zhu · 三月 30, 2021
现已推出三套新的维护版本:
Caché 2018.1.5, Ensemble 2018.1.5, and HSAP 2018.1.5
InterSystems IRIS 2019.1.2, IRIS for Health 2019.1.2, and HealthShare Health Connect 2019.1.2
InterSystems IRIS 2020.1.1, IRIS for Health 2020.1.1, and HealthShare Health Connect 2020.1.1
安装包和容器版本可从以下网站下载 WRC Software Distribution site。
这些都是维护版本,在广泛的领域内有许多更新。 有关这些版本中的修正信息,请参考该版本的文档,其中包括发行说明和升级检查表、发行变更列表,以及类参考资料和全套指南、参考资料、教程和文章。所有的文档都可以通过以下方式获得 docs.intersystems.com 。
在这些版本中也加入了新的平台支持。 特别是,Ubuntu 20.04 LTS的支持已经添加到所有版本中,IBM AIX 7.1和7.2对System p-64的支持已经添加到2019.1.2中(并且已经在2020.1中),而对Linux的ARM64支持已经添加到2020.1.1中。 详情请参见各版本的支持平台文档。
这些版本的构建号如下表所示:
版本
产品
构建号
2018.1.5
Caché and Ensemble
2018.1.5.659.0
2018.1.5
Caché Evaluation
2018.1.5.659.0su
2018.1.5
HealthShare Health Connect (HSAP)
2018.1.5HS.9056.0
2019.1.2
InterSystems IRIS
2019.1.2.718.0
2019.1.2
IRIS for Health
2019.1.2.718.0
2019.1.2
HealthShare Health Connect
2019.1.2.718.0
2020.1.1
InterSystems IRIS
2020.1.1.408.0
2020.1.1
IRIS for Health
2020.1.1.408.0
2020.1.1
HealthShare Health Connect
2020.1.1.408.0
2020.1.1
InterSystems IRIS Community
2020.1.1.408.0
2020.1.1
IRIS for Health Community
2020.1.1.408.0
2020.1.1
IRIS Studio
2020.1.1.408.0
文章
Lele Yang · 二月 21, 2023
** 2018 年 2 月 12 日修订
虽然本文是关于 InterSystems IRIS 的,但它也适用于 Caché、Ensemble 和 HealthShare 发行版。
介绍
内存以页为单位进行管理。 Linux 系统上的默认页面大小为 4KB。 Red Hat Enterprise Linux 6、SUSE Linux Enterprise Server 11 和 Oracle Linux 6 引入了一种根据系统配置提供 2MB 或 1GB 大小的增加页面大小的方法,称为 HugePages。
起初 HugePages 需要在启动时分配,如果管理或计算不当可能会导致资源浪费。因此,各种 Linux 发行版引入了默认启用 2.6.38 内核的Transparent HugePages。这是一种自动创建、管理和使用 HugePages 的方法。以前的内核版本也可能具有此功能,但可能未标记为 [always] 而是设置为 [madvise]。
Transparent Huge Pages (THP) 是一种 Linux 内存管理系统,它通过使用更大的内存页面来减少在具有大量内存的机器上进行Translation Lookaside Buffer (TLB) 查找的开销。然而,在当前的 Linux 版本中,THP 只能映射单个进程的堆栈空间。
问题
任何 Caché 系统中的大部分内存分配都是共享内存段(全局和例程缓冲池),因为 THP 不处理这些共享内存段。因此,THP 不用于共享内存,而仅用于每个单独的进程。这可以使用一个简单的 shell 命令来确认。
以下是来自 InterSystems 的测试系统的示例,其中显示了分配给 Caché 进程的 2MB THP:
# grep -e AnonHugePages /proc/*/smaps | awk '{ if($2>4) print $0} ' | awk -F "/" '{print $0; system("ps -fp " $3)} '
/proc/2945/smaps:AnonHugePages: 2048 kB
UID PID PPID C STIME TTY TIME CMD
root 2945 1 0 2015 ? 01:35:41 /usr/sbin/rsyslogd -n
/proc/70937/smaps:AnonHugePages: 2048 kB
UID PID PPID C STIME TTY TIME CMD
root 70937 70897 0 Jan27 pts/0 00:01:58 /bench/EJR/ycsb161b641/bin/cache WD
/proc/70938/smaps:AnonHugePages: 2048 kB
UID PID PPID C STIME TTY TIME CMD
root 70938 70897 0 Jan27 pts/0 00:00:00 /bench/EJR/ycsb161b641/bin/cache GC
/proc/70939/smaps:AnonHugePages: 2048 kB
UID PID PPID C STIME TTY TIME CMD
root 70939 70897 0 Jan27 pts/0 00:00:39 /bench/EJR/ycsb161b641/bin/cache JD
/proc/70939/smaps:AnonHugePages: 4096 kB
UID PID PPID C STIME TTY TIME CMD
root 70939 70897 0 Jan27 pts/0 00:00:39 /bench/EJR/ycsb161b641/bin/cache JD
/proc/70940/smaps:AnonHugePages: 2048 kB
UID PID PPID C STIME TTY TIME CMD
root 70940 70897 0 Jan27 pts/0 00:00:29 /bench/EJR/ycsb161b641/bin/cache SWD 1
/proc/70941/smaps:AnonHugePages: 2048 kB
UID PID PPID C STIME TTY TIME CMD
root 70941 70897 0 Jan27 pts/0 00:00:29 /bench/EJR/ycsb161b641/bin/cache SWD 2
/proc/70942/smaps:AnonHugePages: 2048 kB
UID PID PPID C STIME TTY TIME CMD
root 70942 70897 0 Jan27 pts/0 00:00:29 /bench/EJR/ycsb161b641/bin/cache SWD 3
/proc/70943/smaps:AnonHugePages: 2048 kB
UID PID PPID C STIME TTY TIME CMD
root 70943 70897 0 Jan27 pts/0 00:00:33 /bench/EJR/ycsb161b641/bin/cache SWD 7
/proc/70944/smaps:AnonHugePages: 2048 kB
UID PID PPID C STIME TTY TIME CMD
root 70944 70897 0 Jan27 pts/0 00:00:29 /bench/EJR/ycsb161b641/bin/cache SWD 4
/proc/70945/smaps:AnonHugePages: 2048 kB
UID PID PPID C STIME TTY TIME CMD
root 70945 70897 0 Jan27 pts/0 00:00:30 /bench/EJR/ycsb161b641/bin/cache SWD 5
/proc/70946/smaps:AnonHugePages: 2048 kB
UID PID PPID C STIME TTY TIME CMD
root 70946 70897 0 Jan27 pts/0 00:00:30 /bench/EJR/ycsb161b641/bin/cache SWD 6
/proc/70947/smaps:AnonHugePages: 4096 kB
此外,运行时内存分配存在潜在的性能损失,尤其是对于具有高作业或进程创建率的应用程序。
建议
InterSystems 建议暂时禁用 THP,因为预期的性能提升不适用于 IRIS 共享内存段,并且可能会对某些应用程序产生负面性能影响。
通过运行以下命令检查您的 Linux 系统是否启用了 Transparent HugePages:
对于 Red Hat Enterprise Linux 内核:
# cat /sys/kernel/mm/redhat_transparent_hugepage/enabled
对于其它内核:
# cat /sys/kernel/mm/transparent_hugepage/enabled
上面的命令将显示是否启用了 [always]、[madvise] 或 [never] 标志。如果从内核中删除 THP,则 /sys/kernel/mm/redhat_transparent_hugepage 或 /sys/kernel/mm/redhat/transparent_hugepage 文件不存在。
要在引导期间禁用透明 HugePages,请执行以下步骤:
1. 将以下条目添加到 /etc/grub.conf 文件中的内核引导行:
transparent_hugepage=never
2.重启操作系统
有一种方法也可以即时禁用 THP,但这可能无法提供所需的结果,因为该方法只会停止为新进程创建和使用 THP。已经创建的 THP 不会被反汇编成常规内存页。建议完全重新启动系统以在启动时禁用 THP。
*注意:建议与您各自的 Linux 经销商确认以确认用于禁用 THP 的方法。
公告
Claire Zheng · 五月 18, 2023
Hi 开发者社区的成员们,大家好!
欢迎关注我们第6期 InterSystems Ideas News!
本期分享如下:
✓ 社区成员上个月实施的创意
✓ 如何在 InterSystems Ideas 上创建新创意
✓ 最近产生的新创意
名人堂更新了实施社区创新想法的社区成员的名字:
将 IRIS 添加为 Apache Superset 的支持数据库,该创意由@Herman Slagman 提出,由 @Dmitry Maslennikov 实施
请添加 google oauth 授权以登录管理门户,该创意由 @Aleksandr Kolesov 提出,由 @Yuri Marx 实施
👏感谢您实践这些创意👏
新文章“ 如何在 InterSystems Ideas 上创建新创意”逐步描述了创意创建的过程。在向门户添加新想法时阅读它。
为了总结本期时事通讯,以下是自上次新闻公告以来发布的新想法列表
1. @Evgeny Shvarov : 转储 SQL 表2. @Dmitry Maslennikov :对 IRIS 的 Java Hibernate 支持3. @Evgeny Shvarov :为 ObjectScript 变量名添加合法的特殊符号分隔符 4.@Robert Cemper :允许取消“待批准” 5.@Robert Cemper :提供隐藏/取消隐藏帖子的开关。或修复重新发布6. @Scott Roth :Java 网关跟踪路由显示7.@John Murray :在开发者社区将动画 GIF 放在播放/暂停按钮后面8. @yurimarx Marx :在 GEO 仪表板上的数字社区9.@Robert Barbiaux :在 VSCode 中进行单元测试10. @Scott Roth :在消息搜索中保存搜索条件11. @yurimarx Marx :特色文章或问题
👏感谢您发布新想法👏
请继续关注下一期 InterSystems Ideas 新闻公告!
保持创意,在InterSystems Ideas上发布您的奇思妙想,对现有想法进行投票和评论!
公告
Claire Zheng · 三月 15, 2023
Hi 开发者社区的成员们,大家好!
欢迎关注我们第4期 InterSystems Ideas News!
我们将分享如下:
如何支持你们team的想法和投票。
在编程大赛中,用户实践Idea(创意)并获得技术奖励。
InterSystems 开发者社区的深色主题版本:是或否(Yay or Nay?)?
最近添加的Idea(创意)。
最重要的消息是,在上一届编程大赛中,有 5 名参赛者因实践InterSystems Ideas 门户网站的创意而获得加分!他们是:
开发者
应用名称
实施的Idea(创意)
@Lorenzo Scalese
OpenAPI-Suite
添加类似于 SOAP 向导的向导,以根据 OpenAPI 规范生成 REST 客户端
@José Roberto Pereira @Henrique Dias @Henry Pereira
iris-tripleslash
添加有助于为 ObjectScript 类生成单元测试的项目
@Sergey Mikhailenko
gateway-sql, apptools-admin
创建一个 UI,以便将项目(类、全局变量、应用程序、用户、角色、特权、授权、命名空间映射、SQL 网关、库等)方便、轻松地传输到其他系统实例以进行快速部署。
我们添加了一个新过滤器“我的组织(My organization)”。从现在开始,来自同一公司的人可以过滤来自同一组织的人的想法和投票。
前几天,@Guillaume Rongier 发布了关于为开发者社区添加深色主题的Idea(创意)。我们非常期待您参与 Ideas Portal 主页上的“民意测验”提供意见反馈,或对该想法进行投票和评论。
最近添加的想法
InterSystems Community 深色版本
为 DC 上的工作机会部分添加工作地点
新功能的可搜索索引
通过环境变量设置密码
安排在 DC 站点上发布文章
在 DC 文本编辑器上支持 JSON
支持 DC 文本编辑器上的 linux bash 语言
使用 SQL 命令将数据从 IRIS 捕获更改为 kafka
跨生产互操作消息、服务和操作
ISC 产品的附加数据类型
DTL、BPL 和规则集中 XData 的自动 XML 格式化
断言 CodeAssist 提示
OpenAI API 的 IRIS 类
在消息属性选项卡上显示 UserValues 内容
虹膜即服务
允许在 VS 代码中对互操作性组件 BPL、DTL 和业务规则进行图形编辑
为所有 IRIS 互操作性组件添加源代码控制
审计查找表
为 WRC 门票添加“观察名单”(问题、问题)
连接 InterSystems 文档和开发人员社区
在 npm 上发布适用于 Node.js 的 InterSystems IRIS Native SDK
像往常一样,在InterSystems Ideas上发布您的想法,对现有想法进行投票和评论,并实践Community Opportunity 的Idea(创意)。
请继续关注我们的下一个新闻公告!
公告
Claire Zheng · 四月 10, 2023
Hi 开发者社区的成员们,大家好!
欢迎关注我们第5期 InterSystems Ideas News!
本期分享如下:
✓名人堂 ——创意社区门户的新页面
✓与 Global Masters 整合——您的每个奇思妙想都可以积分
✓计划实施的想法清单
11 位开发人员已经实施了来自 Ideas Portal 的想法。我们在 InterSystems Ideas 上创建了一个新的专门页面来向这些英雄致敬。名人堂名单:
已实施创意的名称;
实施创意的开发人员;
项目名称(含详细信息链接)。
实施来自Community Opportunity 的创意,您的名字也将进入名人堂!
大约一个月前,提交产品创意的开发人员开始获得这些创意的积分。
我们想分享一下,自 2 月 22 日以来,作者因以下想法共获得了 18,200 Global Masters的积分
发布、推广或实施的 15 个产品创意:
Cross-production Interoperability Messages, Service and Operation by @Stefan Cronje
Additional Data Types for ISC Products by @Stefan Cronje
Change data capture from IRIS to kafka using SQL commands by @Yuri Marx
Allow graphical editing of Interoperability components BPL, DTL and Business Rules in VS Code by @Steve Pisani
Examples to work with IRIS from Django by @Evgeny Shvarov
Install python and java libraries from ZPM and Installation Manifest (%Installer) by @Yuri Marx
Set password through environment variable by @Dmitry Maslennikov
Add a project that helps to generate unittests for an ObjectScript class by @Evgeny Shvarov
Create a UI for convenient and easy transfer of projects (classes, globals, applications, users, roles, privileges, grants, namespace mapping, SQLgateways, libraries, etc.) to other system instances for fast deployment. by @Sergey Mikhailenko
Add a wizard similar to the SOAP wizard to generate a REST client from OpenAPI specification by @Jaime Lerga
Public API for access to shared memory by @Alexey Maslov
Fold code on loops and If's on studio by @Heloisa Paiva
Chat bot to help with TrakCare customization/settings by Sumana Gopinath
Iterative build of TrakCare configuration/code tables utilising FHIR and HL7 Messaging. by Linda McKay
BPL, DTL, Business Rule Editor in VSCode by @Cristiano Silva
发布您的绝妙想法并赢得积分!
为了总结本期通讯,这里列出了计划实施的创意
Publish the InterSystems IRIS Native SDK for Node.js on npm by @John Murray
Move users, roles, resources, user tasks, Mappings (etc) to a seperate Database, other than %SYS, so these items can be mirrored by @Sean.O'Connor1391
Please add google oauth authorization to login to the management portal by @Aleksandr Kolesov
InterSystems Ideas - Long Term by @Vinay Purohit
BPL, DTL, Business Rule Editor in VSCode by @Sawyer Butterfield
Add Favorites in GM by @Irène Mykhailova
LIMIT OFFSET support for IRIS SQL by @Dmitry Maslennikov
Introduce WITH into IRIS SQL engine by @Evgeny Shvarov
Security settings for mirror configurations by @Evgeny Shvarov
A modern management portal to manage InterSystems IRIS by @Evgeny Shvarov
copy/sync system configurations and user accounts between IRIS instances by @Evgeny Shvarov
Jupyter Notebook by Guest
保持创意,在InterSystems Ideas上发布您的奇思妙想,对现有想法进行投票和评论!